假设我有三个模型:
我的关联设置如下:
Task.hasMany(TaskListEntry, {onDelete: 'cascade', hooks: true}));
TaskList.hasMany(TaskListEntry, {onDelete: 'cascade', hooks: true});
TaskListEntry.belongsTo(TaskList);
TaskListEntry.belongsTo(Task);
这工作正常,除了删除。当我删除任务时,任何关联的 TaskListEntries 都会按预期删除。但是,当我删除一个 TaskList 时,其关联的 TaskListEntries 只是将其 TaskList 的外键设置为 null。
似乎 Sequelize 正在生成下表:
CREATE TABLE `TaskListEntries`(
`id` UUID PRIMARY KEY,
/* some other fields here */
`createdAt` DATETIME NOT NULL,
`updatedAt` DATETIME NOT NULL,
`TaskId` UUID REFERENCES `Tasks`(`id`) ON DELETE CASCADE ON UPDATE CASCADE,
`TaskListId` UUID REFERENCES `TaskLists`(`id`) ON DELETE SET NULL ON UPDATE CASCADE);
尽管关联配置相同,但任务和任务列表的外键具有不同的DELETE 行为。如果我删除其中一个关联,另一个就可以正常工作。
因此,我认为问题是 ON DELETE CASCADE 的多个外键,至少就 Sequelize 而言是这样。
关于如何纠正这个问题有什么想法吗?
最佳答案
我必须为 foreignKey 设置 allowNull:false 才能让“CASCADE”在删除时起作用。所以在你的情况下应该是这样的:
TaskListEntry.belongsTo(TaskList, {
onDelete: 'cascade',
foreignKey: { allowNull: false } // <-------------
hooks: true
});
鉴于这种情况,您的模型通常类似于 http://docs.sequelizejs.com/manual/associations.html#belongs-to-many-associations 中的这种结构:
class User extends Model {}
User.init({}, { sequelize, modelName: 'user' })
class Project extends Model {}
Project.init({}, { sequelize, modelName: 'project' })
class UserProjects extends Model {}
UserProjects.init({
status: DataTypes.STRING
}, { sequelize, modelName: 'userProjects' })
User.belongsToMany(Project, { through: UserProjects })
Project.belongsToMany(User, { through: UserProjects })
关于sql - ON DELETE CASCADE for multiple foreign keys with Sequelize,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56213758/