如何解决追加条件的续集
我目前正在使用带有node.js的sequelize v5。我正在尝试使用upsert创建新行或更新现有行,但我希望仅在满足条件时才触发更新。
await Model.upsert({values});
在模型表中,我有一个布尔列。如果布尔值为true,我希望更新不覆盖现有行。我想也许我可以为beforeUpdate或beforeSave使用一个钩子,但我找不到它。
编辑:如果重要的话,我正在使用PostgreSQL。
解决方法
假设您有一个名为User
的模型
您声明了模型类
class User extends Model {}
User.init({
username: DataTypes.STRING,mood: {
type: DataTypes.ENUM,values: ['happy','sad','neutral']
}
});
您可以像这样广告钩子
User.beforeUpsert(user,options) => {
if(user.condition){
... do stuff
}
});
,
对于v5中的upsert操作,已经有一个 beforeUpsert
钩子,请尝试一下可能会有所帮助。
这是Sequelize v5的doc,您可以在其中找到所有的钩子及其用法
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。