大佬教程收集整理的这篇文章主要介绍了SequelizeForeignKeyConstraintError:更新或删除表 X 违反表 Y 上的外键约束 fkey,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我在更新用户表中的显示名称时遇到问题,出现以下错误。
关系
用户也可以是主管。并且两个表都有一个名称字段(用户的 displayname 和主管的名称)。如果用户 X 编辑他的个人资料并更改显示名称,我希望更改反映在主管表名称字段中。我虽然级联可以工作,但我没有得到它。
(node:25136) UnhandledPromiseRejectionWarning: SequelizeForeignKeyConsTraintError: update or delete on table "c_user" violates foreign key consTraint "c_supervisor_name_fkey" on table "c_supervisor"
用户表和主管表之间存在 1:n 关系。
用户模型
const User = sequelize.define('user',{
ID: {
type: Sequelize.IntegeR,allowNull: false,primaryKey: true,autoIncrement: true
},displayname: {
type: Sequelize.StriNG,unique: true
},User.associate = function(models) {
User.hasOne(models.supervisor,{ ForeignKey: "userID" });
};
User.hasOne(models.supervisor,{ ForeignKey: "name" });
return User;
};
主管模式
@H_909_11@module.exports = (sequelize,SequelizE) => { const Supervisor = sequelize.define('supervisor',{ ID: { type: Sequelize.IntegeR,autoIncrement: true },userID: { type: Sequelize.IntegeR,unique: true,references: { model: 'c_user',key: 'ID' } },name: { type: Sequelize.StriNG,key: 'displayname' } },Supervisor.associate = function(models) { Supervisor.belongsTo(modelS.User,{ ForeignKey: "userID",targetKey: "ID",ondelete: "CASCADE",onupdate: "CASCADE" }); Supervisor.belongsTo(modelS.User,{ ForeignKey: "name",targetKey: "displayname",onupdate: "CASCADE" }); } return Supervisor; };
如果我更新用户表中的显示名称,我希望它级联到主管中的名称并更新它,但我得到了上面的错误。
首先使用名称作为外键是个坏主意。其次,如果将两个相同的表相互关联,则需要使用别名来区分它们的关联方式。例如:
// user-to-supervisor one to one relation as user
User.hasOne(Supervisor,{ForeignKey: 'userId',as: 'user'})
Supervisor.belongsTo(User)
// user-to-supervisor one to one relation as username
User.hasOne(Supervisor,{ForeignKey: 'name',as: 'username'})
Supervisor.belongsTo(User)
希望它会有所帮助,但是您尝试做的事情不切实际。 你能更具体地描述一下你想要达到的关系吗。
以上是大佬教程为你收集整理的SequelizeForeignKeyConstraintError:更新或删除表 X 违反表 Y 上的外键约束 fkey全部内容,希望文章能够帮你解决SequelizeForeignKeyConstraintError:更新或删除表 X 违反表 Y 上的外键约束 fkey所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。