因为我的外键是在建表的时候,创建的。
当时把外键设置成了“ON DELETE NO ACTION ON UPDATE NO ACTION”(不进行删除,更新操作)
结果在映射文件中设置 cascade=“delete” 也不能进行删除
解决办法1:
代码解决(把这里的外键与表名改成自己的)
ALTER TABLE crm.cst_ man
DROP FOREIGN KEY FK_cst_ man_lkm_cust_id

ALTER TABLE crm.cst_ man
ADD CONSTRAINT FK_cst_ man_lkm_cust_id
FOREIGN KEY (lkm_cust_id)
REFERENCES crm.cst_customer (cust_id)
ON DELETE CASCADE
ON UPDATE CASCADE,
方法2:
这时候把图形化数据库打开:
\"在这里插入图片描述\"点开扳手
\"在这里插入图片描述\"点到Foreign Keys界面,再把对应外键的On Update与On Delete设置成CASCADE
点apply后会自动生成代码,提交代码,更新数据库。
问题解决!
这里提一下On Update,On Delete中几个值的区别

.cascade方式
在父表上update/delete记录时,同步update/delete掉子表的匹配记录

. set null方式
在父表上update/delete记录时,将子表上匹配记录的列设为null
要注意子表的外键列不能为not null

. No action方式
如果子表中有匹配的记录,则不允许对父表对应候选键进行update/delete操作

. Restrict方式
同no action, 都是立即检查外键约束

. Set default方式
父表有变更时,子表将外键列设置成一个默认的值 但Innodb不能识别

收藏 打印