aguo718 2017-09-04 02:53 采纳率: 61.9%
浏览 3866
已采纳

在mysql5.7中实现级联删除,即删除主表中信息的同时删除参照表中对应记录,求大神指导

参照表中设置了级联删除和级联更新但是没有实现。。
上网搜索后用触发器如下

 CREATE TRIGGER deleUser_trigger
BEFORE DELETE ON users FOR EACH ROW 
BEGIN
 DELETE FROM stuinfo WHERE stu_id=old.id;
END;

然后。。。报错

 You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '' at line 4

mysql版本5.7
不知道该怎么解决,新手求指导
(另外这一过程也可以在java中实现,但觉得在数据库中实现更好些,所以想在问一下,这两种实现方式有哪些区别吗,是减少java中代码量吗)

  • 写回答

4条回答 默认 最新

  • 易燃易炸佛系少女 2017-09-04 03:46
    关注

    可以设置外键约束吧

    图片说明

    1. CASCADE: 从父表中删除或更新对应的行,同时自动的删除或更新自表中匹配的行。
    2. SET NULL: 从父表中删除或更新对应的行,同时将子表中的外键列设为空。注意,这些在外键列没有被设为NOT NULL时才有效。
    3. NO ACTION: InnoDB拒绝删除或者更新父表。
    4. RESTRICT: 拒绝删除或者更新父表。指定RESTRICT(或者NO ACTION)和忽略ON DELETE或者ON UPDATE选项的效果是一样的。
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料
  • ¥15 使用R语言marginaleffects包进行边际效应图绘制
  • ¥20 usb设备兼容性问题
  • ¥15 错误(10048): “调用exui内部功能”库命令的参数“参数4”不能接受空数据。怎么解决啊
  • ¥15 安装svn网络有问题怎么办