У меня есть 3 модели, продукта, возраст и ProductAgesКак добавить hasToMany отношения Sequelize?
product.js
'use strict';
module.exports = function(sequelize, DataTypes){
var Product = sequelize.define('Product', {
sku: DataTypes.STRING,
name: DataTypes.STRING,
value: DataTypes.STRING,
body: DataTypes.TEXT
}, {
associate: function(models) {
Product.belongsToMany(models.Age, {through: models.ProductAges});
}
});
return Product;
}
age.js
'use strict';
module.exports = function(sequelize, DataTypes) {
var Age = sequelize.define('Age', {
name: DataTypes.STRING,
value: DataTypes.STRING
},{
associate: function(models) {
Age.belongsToMany(models.Product, {through: models.ProductAges})
}
}
);
return Age;
};
продакт-age.js
'use strict';
module.exports = function(sequelize, DataTypes){
var ProductAges = sequelize.define('ProductAges', {
id: {
type: DataTypes.INTEGER,
primaryKey: true,
autoIncrement: true
}
});
return ProductAges;
}
в функция Create, в контроллере продуктов:
exports.create = function(req, res){
// save and return and instance of product on the res object
console.log('Request Body ==> ', req.body);
// {
// sku: '123',
// name: 'ប៉ោម',
// value: 'Apple',
// body: 'ល្អណាស់',
// ages:[{
// id: 1,
// name: 'តិចជាង ១៩ ឆ្នាំ',
// value: 'less_than_19',
// createdAt: '2016-07-08T12:47:06.000Z',
// updatedAt: '2016-07-08T13:10:10.000Z',
// ticked: true
// },{
// id: 3,
// name: 'ចន្លោះ ២០ ទៅ ២៤ ឆ្នាំ',
// value: 'between_20_24',
// createdAt: '2016-07-08T12:59:05.000Z',
// updatedAt: '2016-07-08T12:59:05.000Z',
// ticked: true
// }]
// }
db.Product.create(req.body).then(function(product){
if (!product){
return res.send('user/signup', {errors: new StandardError('Product could not be created')});
}
else{
return res.jsonp(product);
}
}).catch(function(err){
return res.send('users/signup', {
error: err,
status: 500
})
})
};
Это прекрасно работает только для вставки продукта. Тем не менее, я также хочу вставить в модель ProductAges с помощью функции addAges в соответствии с Sequelize Docs here.
Итак, я изменил создать функцию контроллера в этом:
exports.create = function(req, res){
// save and return and instance of product on the res object
db.Product.create(req.body).then(function(product){
if (!product){
return res.send('user/signup', {errors: new StandardError('Product could not be created')});
}
else{
db.Product.addAges(req.body.ages);
return res.jsonp(product);
}
}).catch(function(err){
return res.send('users/signup', {
error: err,
status: 500
})
})
};
Я получил этот журнал ошибок:
verbose: Executing (default): SELECT `data` FROM `Sessions` AS `Session` WHERE `Session`.`sid` = 'Qzad_nN3rMR2RrsZ-Oa3H4A5BfL2optm' LIMIT 1;
verbose: Executing (default): SELECT `id`, `name`, `email`, `username`, `hashedPassword`, `provider`, `salt`, `facebookUserId`, `twitterUserId`, `twitterKey`, `twitterSecret`, `github`, `openId`, `createdAt`, `updatedAt` FROM `Users` AS `User` WHERE `User`.`id` = 1;
info: Session: { id: 1, username: john }
verbose: Executing (default): INSERT INTO `Products` (`id`,`sku`,`name`,`value`,`body`,`createdAt`,`updatedAt`) VALUES (DEFAULT,'123','ប៉ោម','Apple','ល្អណាស់','2016-07-08 16:26:44','2016-07-08 16:26:44');
Fri, 08 Jul 2016 16:26:44 GMT express deprecated res.send(status, body): Use res.status(status).send(body) instead at app/controllers/products.js:45:20
verbose: Executing (default): SELECT `id`, `sid`, `data`, `createdAt`, `updatedAt` FROM `Sessions` AS `Session` WHERE `Session`.`sid` = 'Qzad_nN3rMR2RrsZ-Oa3H4A5BfL2optm' LIMIT 1;
Unhandled rejection RangeError: Invalid status code: 0
at ServerResponse.writeHead (_http_server.js:192:11)
at ServerResponse.writeHead (/Users/Roller/Working/Web/ponds_web/node_modules/on-headers/index.js:55:19)
at ServerResponse.writeHead (/Users/Roller/Working/Web/ponds_web/node_modules/on-headers/index.js:55:19)
at ServerResponse.writeHead (/Users/Roller/Working/Web/ponds_web/node_modules/on-headers/index.js:55:19)
at ServerResponse._implicitHeader (_http_server.js:157:8)
at ServerResponse.write (/Users/Roller/Working/Web/ponds_web/node_modules/compression/index.js:83:14)
at writetop (/Users/Roller/Working/Web/ponds_web/node_modules/express-session/index.js:286:26)
at ServerResponse.end (/Users/Roller/Working/Web/ponds_web/node_modules/express-session/index.js:328:16)
at ServerResponse.send (/Users/Roller/Working/Web/ponds_web/node_modules/express/lib/response.js:205:10)
at ServerResponse.json (/Users/Roller/Working/Web/ponds_web/node_modules/express/lib/response.js:250:15)
at ServerResponse.send (/Users/Roller/Working/Web/ponds_web/node_modules/express/lib/response.js:152:21)
at .<anonymous> (/Users/Roller/Working/Web/ponds_web/app/controllers/products.js:45:20)
at tryCatcher (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/util.js:16:23)
at Promise._settlePromiseFromHandler (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/promise.js:504:31)
at Promise._settlePromise (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/promise.js:561:18)
at Promise._settlePromise0 (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/promise.js:606:10)
Unhandled rejection RangeError: Invalid status code: 0
at ServerResponse.writeHead (_http_server.js:192:11)
at ServerResponse.writeHead (/Users/Roller/Working/Web/ponds_web/node_modules/on-headers/index.js:55:19)
at ServerResponse.writeHead (/Users/Roller/Working/Web/ponds_web/node_modules/on-headers/index.js:55:19)
at ServerResponse.writeHead (/Users/Roller/Working/Web/ponds_web/node_modules/on-headers/index.js:55:19)
at ServerResponse._implicitHeader (_http_server.js:157:8)
at ServerResponse.end (/Users/Roller/Working/Web/ponds_web/node_modules/compression/index.js:102:14)
at writeend (/Users/Roller/Working/Web/ponds_web/node_modules/express-session/index.js:257:22)
at onsave (/Users/Roller/Working/Web/ponds_web/node_modules/express-session/index.js:325:11)
at .<anonymous> (/Users/Roller/Working/Web/ponds_web/node_modules/express-sequelize-session/lib/e4store.js:90:51)
at tryCatcher (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/util.js:16:23)
at Promise._settlePromiseFromHandler (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/promise.js:504:31)
at Promise._settlePromise (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/promise.js:561:18)
at Promise._settlePromise0 (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/promise.js:606:10)
at Promise._settlePromises (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/promise.js:681:18)
at Async._drainQueue (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/async.js:138:16)
at Async._drainQueues (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/async.js:148:10)
error: RangeError: Invalid status code: 0
at ServerResponse.writeHead (_http_server.js:192:11)
at ServerResponse.writeHead (/Users/Roller/Working/Web/ponds_web/node_modules/on-headers/index.js:55:19)
at ServerResponse.writeHead (/Users/Roller/Working/Web/ponds_web/node_modules/on-headers/index.js:55:19)
at ServerResponse.writeHead (/Users/Roller/Working/Web/ponds_web/node_modules/on-headers/index.js:55:19)
at ServerResponse._implicitHeader (_http_server.js:157:8)
at ServerResponse.end (/Users/Roller/Working/Web/ponds_web/node_modules/compression/index.js:102:14)
at writeend (/Users/Roller/Working/Web/ponds_web/node_modules/express-session/index.js:257:22)
at onsave (/Users/Roller/Working/Web/ponds_web/node_modules/express-session/index.js:325:11)
at .<anonymous> (/Users/Roller/Working/Web/ponds_web/node_modules/express-sequelize-session/lib/e4store.js:88:51)
at tryCatcher (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/util.js:16:23)
at Promise._settlePromiseFromHandler (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/promise.js:504:31)
at Promise._settlePromise (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/promise.js:561:18)
at Promise._settlePromise0 (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/promise.js:606:10)
at Promise._settlePromises (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/promise.js:685:18)
at Async._drainQueue (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/async.js:138:16)
at Async._drainQueues (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/async.js:148:10)
Warning: Unexpected block "main" on line 3 of /Users/Roller/Working/Web/ponds_web/app/views/500.jade. This block is never used. This warning will be an error in v2.0.0
Затем я попытался использовать обещание, как это:
exports.create = function(req, res){
// save and return and instance of product on the res object
db.Product.create(req.body).then(function(product){
if (!product){
return res.send('user/signup', {errors: new StandardError('Product could not be created')});
}
else{
db.Product.addAges(ages).then(function(){
return res.jsonp(product);
});
}
}).catch(function(err){
return res.send('users/signup', {
error: err,
status: 500
})
})
};
После этого я получил эту ошибку:
verbose: Executing (default): SELECT `data` FROM `Sessions` AS `Session` WHERE `Session`.`sid` = 'Qzad_nN3rMR2RrsZ-Oa3H4A5BfL2optm' LIMIT 1;
verbose: Executing (default): SELECT `id`, `name`, `email`, `username`, `hashedPassword`, `provider`, `salt`, `facebookUserId`, `twitterUserId`, `twitterKey`, `twitterSecret`, `github`, `openId`, `createdAt`, `updatedAt` FROM `Users` AS `User` WHERE `User`.`id` = 1;
info: Session: { id: 1, username: john }
verbose: Executing (default): INSERT INTO `Products` (`id`,`sku`,`name`,`value`,`body`,`createdAt`,`updatedAt`) VALUES (DEFAULT,'123','ប៉ោម','Apple','ល្អណាស់','2016-07-08 16:30:17','2016-07-08 16:30:17');
verbose: Executing (default): SELECT `id`, `sid`, `data`, `createdAt`, `updatedAt` FROM `Sessions` AS `Session` WHERE `Session`.`sid` = 'Qzad_nN3rMR2RrsZ-Oa3H4A5BfL2optm' LIMIT 1;
Unhandled rejection RangeError: Invalid status code: 0
at ServerResponse.writeHead (_http_server.js:192:11)
at ServerResponse.writeHead (/Users/Roller/Working/Web/ponds_web/node_modules/on-headers/index.js:55:19)
at ServerResponse.writeHead (/Users/Roller/Working/Web/ponds_web/node_modules/on-headers/index.js:55:19)
at ServerResponse.writeHead (/Users/Roller/Working/Web/ponds_web/node_modules/on-headers/index.js:55:19)
at ServerResponse._implicitHeader (_http_server.js:157:8)
at ServerResponse.write (/Users/Roller/Working/Web/ponds_web/node_modules/compression/index.js:83:14)
at writetop (/Users/Roller/Working/Web/ponds_web/node_modules/express-session/index.js:286:26)
at ServerResponse.end (/Users/Roller/Working/Web/ponds_web/node_modules/express-session/index.js:328:16)
at ServerResponse.send (/Users/Roller/Working/Web/ponds_web/node_modules/express/lib/response.js:205:10)
at ServerResponse.json (/Users/Roller/Working/Web/ponds_web/node_modules/express/lib/response.js:250:15)
at ServerResponse.send (/Users/Roller/Working/Web/ponds_web/node_modules/express/lib/response.js:152:21)
at .<anonymous> (/Users/Roller/Working/Web/ponds_web/app/controllers/products.js:46:20)
at tryCatcher (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/util.js:16:23)
at Promise._settlePromiseFromHandler (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/promise.js:504:31)
at Promise._settlePromise (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/promise.js:561:18)
at Promise._settlePromise0 (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/promise.js:606:10)
Unhandled rejection RangeError: Invalid status code: 0
at ServerResponse.writeHead (_http_server.js:192:11)
at ServerResponse.writeHead (/Users/Roller/Working/Web/ponds_web/node_modules/on-headers/index.js:55:19)
at ServerResponse.writeHead (/Users/Roller/Working/Web/ponds_web/node_modules/on-headers/index.js:55:19)
at ServerResponse.writeHead (/Users/Roller/Working/Web/ponds_web/node_modules/on-headers/index.js:55:19)
at ServerResponse._implicitHeader (_http_server.js:157:8)
at ServerResponse.end (/Users/Roller/Working/Web/ponds_web/node_modules/compression/index.js:102:14)
at writeend (/Users/Roller/Working/Web/ponds_web/node_modules/express-session/index.js:257:22)
at onsave (/Users/Roller/Working/Web/ponds_web/node_modules/express-session/index.js:325:11)
at .<anonymous> (/Users/Roller/Working/Web/ponds_web/node_modules/express-sequelize-session/lib/e4store.js:90:51)
at tryCatcher (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/util.js:16:23)
at Promise._settlePromiseFromHandler (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/promise.js:504:31)
at Promise._settlePromise (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/promise.js:561:18)
at Promise._settlePromise0 (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/promise.js:606:10)
at Promise._settlePromises (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/promise.js:681:18)
at Async._drainQueue (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/async.js:138:16)
at Async._drainQueues (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/async.js:148:10)
error: RangeError: Invalid status code: 0
at ServerResponse.writeHead (_http_server.js:192:11)
at ServerResponse.writeHead (/Users/Roller/Working/Web/ponds_web/node_modules/on-headers/index.js:55:19)
at ServerResponse.writeHead (/Users/Roller/Working/Web/ponds_web/node_modules/on-headers/index.js:55:19)
at ServerResponse.writeHead (/Users/Roller/Working/Web/ponds_web/node_modules/on-headers/index.js:55:19)
at ServerResponse._implicitHeader (_http_server.js:157:8)
at ServerResponse.end (/Users/Roller/Working/Web/ponds_web/node_modules/compression/index.js:102:14)
at writeend (/Users/Roller/Working/Web/ponds_web/node_modules/express-session/index.js:257:22)
at onsave (/Users/Roller/Working/Web/ponds_web/node_modules/express-session/index.js:325:11)
at .<anonymous> (/Users/Roller/Working/Web/ponds_web/node_modules/express-sequelize-session/lib/e4store.js:88:51)
at tryCatcher (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/util.js:16:23)
at Promise._settlePromiseFromHandler (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/promise.js:504:31)
at Promise._settlePromise (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/promise.js:561:18)
at Promise._settlePromise0 (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/promise.js:606:10)
at Promise._settlePromises (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/promise.js:685:18)
at Async._drainQueue (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/async.js:138:16)
at Async._drainQueues (/Users/Roller/Working/Web/ponds_web/node_modules/bluebird/js/release/async.js:148:10)
Warning: Unexpected block "main" on line 3 of /Users/Roller/Working/Web/ponds_web/app/views/500.jade. This block is never used. This warning will be an error in v2.0.0
Это насколько я могу идти. Я действительно не хочу писать ProductAges Controller для ручного добавления ProductId и AgeId в модель ProductAges после создания нового продукта. Поскольку уже есть встроенная функция, вы можете добавить данные таблицы пересечений. Sequelize Belongs-To-Many associations Я уверен, что есть более простой способ.
Пожалуйста, помогите направить. Благодарю.