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

相關文章
相關標籤/搜索