Sequelize.js insert a model with one-to-many relationship(Sequelize.js 插入具有一对多关系的模型)
问题描述
我有两个具有一对多关系的续集模型.我们称它们为所有者和财产.
I have two sequelize models with one-to-many relationship. Let's call them Owner and Property.
假设它们是使用sails-hook-sequelize 定义的(简化).
Assume they are defined using the sails-hook-sequelize as such (simplified).
//Owner.js
module.exports = {
options: {
tableName: 'owner'
},
attributes: {
id: {
type: Sequelize.BIGINT,
allowNull: false,
primaryKey: true,
autoIncrement: true
},
name: {
type: Sequelize.STRING(255)
},
associations: function () {
Owner.hasMany(Property, {
foreignKey: {
name: 'owner_id'
}
});
}
}
//Property.js
module.exports = {
options: {
tableName: 'property'
},
attributes: {
id: {
type: Sequelize.BIGINT,
allowNull: false,
primaryKey: true,
autoIncrement: true
},
name: {
type: Sequelize.STRING(255)
}
}
现在假设我想在我的数据库中插入一个所有者记录并插入一些属性记录以与所有者关联.我该怎么做呢?
Now assume I want to insert an Owner record in my database and insert a few property records to associate with the owner. How do I do this?
我正在寻找类似的东西
Owner.create({name:'nice owner',
property: [{name:'nice property'},
{name:'ugly property'}]});
令人惊讶的是,我在 Sequelize 文档中找不到这个.
Surprisingly I can't find this in the Sequelize documentation.
推荐答案
您不能在创建所有者时关联属性现有记录,您必须在之后立即使用承诺链.
You can't associate property existing records when you create the owner, you have to do that right after, with promise chain.
Owner.create({name:'nice owner'}).then(function(owner){
owner.setProperties([{name:'nice property'}, {name:'ugly property'}]).then(/*...*/);
});
为避免这些关联出现任何问题(所有者已创建但某些关联失败),最好使用事务.
To avoid any problems with those associations (owner created but some associations failed), it's better to use transactions.
sequelize.transaction(function(t) {
return Owner.create({name:'nice owner'}, {transaction: t}).then(function(owner){
return owner.setProperties([{name:'nice property'}, {name:'ugly property'}], {transaction : t});
});
});
但是,如果您想创建与新属性关联的新所有者,您可以执行类似的操作
However, if you want to create new Owner associated to new Properties you can do something like
Owner.create({
name: 'nice owner',
property: [
{ name: 'nice property'},
{ name: 'ugly property'}
]
},{
include: [ Property]
});
参见 http://docs.sequelizejs.com/zh/latest/docs/associations/#creating-with-associations
这篇关于Sequelize.js 插入具有一对多关系的模型的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:Sequelize.js 插入具有一对多关系的模型
基础教程推荐
- Vue 3 – <过渡>渲染不能动画的非元素根节点 2022-01-01
- html表格如何通过更改悬停边框来突出显示列? 2022-01-01
- 如何使用TypeScrip将固定承诺数组中的项设置为可选 2022-01-01
- Chart.js 在线性图表上拖动点 2022-01-01
- 用于 Twitter 小部件宽度的 HTML/CSS 2022-01-01
- 我可以在浏览器中与Babel一起使用ES模块,而不捆绑我的代码吗? 2022-01-01
- 直接将值设置为滑块 2022-01-01
- 如何使用JIT在顺风css中使用布局变体? 2022-01-01
- Electron 将 Node.js 和 Chromium 上下文结合起来意味着 2022-01-01
- 自定义 XMLHttpRequest.prototype.open 2022-01-01