在将新记录插入数据库之前,我需要执行一些检查,然后确定是否可以插入该记录。我以为可以使用beforeCreate钩子来做这样的事情:
Data.beforeCreate(function(object, options) {
Data.scope('complexQuery').findAll().then(function (result) {
if (result.length >= 1) {
// do not insert the record
}
else {
// go ahead and insert
}
});
});
关于如何停止记录创建的任何想法?
这是正确的方法吗?
您可以抛出错误,也可以拒绝承诺:
Data.beforeCreate(function(object, options) {
Data.scope('complexQuery').findAll().then(function (result) {
if (result.length >= 1) {
throw new Error('Already exists')
return sequelize.Promise.reject('Already exists')
}
else {
// go ahead and insert
}
});
});
由于您实际上是在进行验证,因此它可能更适合作为验证功能:)
sequelize.define('model', attributes, {
validate: {
complexQuery: function () {
// Do the validation here instead
}
}
});
验证同时针对创建和更新运行
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句