मुझे लगता है कि त्रुटि यह है कि आपने टाइमस्टैम्प को सीक्वल करने में सक्षम किया है, लेकिन डीबी में आपकी वास्तविक तालिका परिभाषा में टाइमस्टैम्प कॉलम नहीं है।
जब आप user.find करते हैं SELECT user.*
, तो यह सिर्फ वह करेगा , जो केवल आपके पास मौजूद कॉलम लेता है। लेकिन जब आप शामिल होते हैं, तो शामिल की गई तालिका के प्रत्येक स्तंभ को अलियास किया जाएगा, जो निम्नलिखित प्रश्न बनाता है:
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`;
फिक्स टाइमस्टैम्प को या तो यूजरडेल्स मॉडल के लिए निष्क्रिय करना होगा:
var userDetails = sequelize.define('userDetails', {
userId :Sequelize.INTEGER,
firstName : Sequelize.STRING,
lastName : Sequelize.STRING,
birthday : Sequelize.DATE
}, {
timestamps: false
});
या सभी मॉडलों के लिए:
var sequelize = new Sequelize('sequelize_test', 'root', null, {
host: "127.0.0.1",
dialect: 'mysql',
define: {
timestamps: false
}
});