Sequelize Unknown column '*.createdAt' in 'field list'

匿名 (未验证) 提交于 2019-12-03 02:16:02

问题:

I'm getting a Unknown column 'userDetails.createdAt' in 'field list' When trying to fetch with association.

Using findAll without association works fine.

My code is as follows:

var userDetails = sequelize.define('userDetails', {     userId :Sequelize.INTEGER,     firstName : Sequelize.STRING,     lastName : Sequelize.STRING,     birthday : Sequelize.DATE });  var user = sequelize.define('user', {     email: Sequelize.STRING,     password: Sequelize.STRING });  user.hasOne(userDetails, {foreignKey: 'userId'});  user.findAll({include: [userDetails] }).success(function(user) {     console.log(user) }); 

回答1:

I think the error is that you have timestamps enabled in sequelize, but your actual table definitions in the DB do not contain a timestamp column.

When you do user.find it will just do SELECT user.*, which only takes the columns you actually have. But when you join, each column of the joined table will be aliased, which creates the following query:

SELECT `users`.*, `userDetails`.`userId` AS `userDetails.userId`,`userDetails`.`firstName` AS `userDetails.firstName`,`userDetails`.`lastName` AS `userDetails.lastName`, `userDetails`.`birthday` AS `userDetails.birthday`, `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`; 

The fix would be to disable timestamps for either the userDetails model:

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

or for all models:

var sequelize = new Sequelize('sequelize_test', 'root', null, {     host: "127.0.0.1",     dialect: 'mysql',     define: {         timestamps: false     } }); 


易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!