程序问答   发布时间:2022-06-02  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了SequelizeForeignKeyConstraintError:更新或删除表 X 违反表 Y 上的外键约束 fkey大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

如何解决SequelizeForeignKeyConsTraintError:更新或删除表 X 违反表 Y 上的外键约束 fkey?

开发过程中遇到SequelizeForeignKeyConsTraintError:更新或删除表 X 违反表 Y 上的外键约束 fkey的问题如何解决?下面主要结合日常开发的经验,给出你关于SequelizeForeignKeyConsTraintError:更新或删除表 X 违反表 Y 上的外键约束 fkey的解决方法建议,希望对你解决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,请注明来意。