我是Sequelize的新手,所以我有一个非常简单,也许是微不足道的问题。考虑一下文档上的示例:
var project = Project.build({
title: 'my awesome project',
description: 'woot woot. this will make me a rich man'
})
var task = Task.build({
title: 'specify the project idea',
description: 'bla',
deadline: new Date()
})
我想确保我要么既保存也不保存。我怎么做? 换句话说,我如何在多个表上自动执行创建/更新操作?
答案 0 :(得分:4)
简而言之,使用交易:
sequelize.transaction().then(function (t) {
return sequelize.Promise.all([
Project.create({
title: 'my awesome project',
description: 'woot woot. this will make me a rich man'
}, { transaction: t }),
Task.build({
title: 'specify the project idea',
description: 'bla',
deadline: new Date()
}, { transaction: t })
]).then(function onFulfilled (project, task) {
return t.commit();
}, function onRejected(err) {
return t.rollback();
});
});
在最新版本(2.0-rc2)中,这也可以更简洁地写成:
sequelize.transaction(function (t) {
return sequelize.Promise.all([
Project.create({
title: 'my awesome project',
description: 'woot woot. this will make me a rich man'
}, { transaction: t }),
Task.build({
title: 'specify the project idea',
description: 'bla',
deadline: new Date()
}, { transaction: t })
]);
});
将回调传递给transaction
,而不是调用then
。回调返回一个promsie链,并且提交或回滚事务,具体取决于返回的promise的成功。这意味着如果传递给Promise.all
的任何操作失败,则事务将被回滚。