douyuan1049 2013-04-03 06:32
浏览 51

无法调用MySQL触发器

Creating a trigger is successful

mysqli_query($this->conn,
   "CREATE TRIGGER `before_delete_address`
    BEFORE DELETE ON address FOR EACH ROW
    DELETE FROM city WHERE cityid = OLD.cityid");

but when I execute the following query

DELETE FROM address WHERE addressid = 18

it outputs the following error code

Error Code: 1451. Cannot delete or update a parent row: a foreign key constraint fails (`gamecomp`.`address`, CONSTRAINT `cityid` FOREIGN KEY (`cityid`) REFERENCES `city` (`cityid`) ON UPDATE CASCADE)    0.039 sec

The constraints on the address table are set to On Update cascade and On Delete restrict.

The columns of the address table are addressid, address, cityid, zipcode, cityid is a FK reference to the city table contains cityid, city, countryid

Can someone point out what I have done wrong? thanks

  • 写回答

2条回答 默认 最新

  • dongpang4470 2013-04-03 06:36
    关注

    instead of BEFORE DELETE ON city use AFTER DELETE ON address

    评论

报告相同问题?

悬赏问题

  • ¥50 永磁型步进电机PID算法
  • ¥15 sqlite 附加(attach database)加密数据库时,返回26是什么原因呢?
  • ¥88 找成都本地经验丰富懂小程序开发的技术大咖
  • ¥15 如何处理复杂数据表格的除法运算
  • ¥15 如何用stc8h1k08的片子做485数据透传的功能?(关键词-串口)
  • ¥15 有兄弟姐妹会用word插图功能制作类似citespace的图片吗?
  • ¥200 uniapp长期运行卡死问题解决
  • ¥15 latex怎么处理论文引理引用参考文献
  • ¥15 请教:如何用postman调用本地虚拟机区块链接上的合约?
  • ¥15 为什么使用javacv转封装rtsp为rtmp时出现如下问题:[h264 @ 000000004faf7500]no frame?