Sequelize Unknown column 'createdAt' in 'field list'?

报错:

在使用sequelize建立model后,使用model进行findAll查询的时候报错:mysql

Sequelize Unknown column '*.createdAt' in 'field list'?程序员

报错缘由:

在sequelize中启用了时间戳(即sequelize中建立的model开启了时间戳),可是在数据库中的实际表定义不包含时间戳列。sql

当你作model.findAll时,会将model中的每一进行别名查询(也包括model中开启的时间戳),从而建立下面例子查询,这面就包含了数据库中实际没有的时间戳列(createdAt,updatedAt):数据库

SELECT `users`.*, `userDetails`.`userId` AS `userDetails.userId`,`userDetails`.`firstName` AS `userDetails.firstName`, `userDetails`.`id` AS `userDetails.id`, `userDetails`.`createdAt` AS `userDetails.createdAt`, `userDetails`.`updatedAt` AS `userDetails.updatedAt` FROM `users` LEFT OUTER JOIN `userDetails` AS `userDetails` ON `users`.`id` = `userDetails`.`userId`;

复制代码

解决办法

在model建立的时候禁用时间戳,例如禁用userDetails模型的时间戳:bash

var userDetails = sequelize.define('userDetails', {
    userId :Sequelize.INTEGER,
    firstName : Sequelize.STRING,
    lastName : Sequelize.STRING,
    birthday : Sequelize.DATE
}, {
    timestamps: false
});
复制代码

或在sequelize链接mysql的时候,直接禁用全部时间戳开启:微信

var sequelize = new Sequelize('sequelize_test', 'root', null, {
    host: "127.0.0.1",
    dialect: 'mysql',
    define: {
        timestamps: false
    }
});
复制代码
以为本文对你有帮助?请分享给更多人

个人公众号.jpg

欢迎你们关注个人公众号——程序员成长指北。请自行微信搜索——“程序员成长指北”spa

相关文章
相关标签/搜索