为什么通过这种表关系获得“多个级联路径”?-问答-阿里云开发者社区-阿里云

开发者社区> 心有灵_夕> 正文

为什么通过这种表关系获得“多个级联路径”?

2019-12-29 13:17:50 2583 1

我的数据库中具有以下表关系:

Parent
          /    \
    Child1      Child2
        \        /
        GrandChild

我正在尝试创建FK关系,以便父表的删除级联到子表和孙表。对于任何一个特定的Granchild,它将要么成为一个或另一个子表的父项,但决不会同时存在。

当我尝试在FK关系中添加DELETE CASCADE时,将它们添加到两个孩子的一个“边”中就可以了(Parent-Child1-GrandChild对于“级联删除”是很好的)。但是,一旦我在关系的Child2“边”上添加了Cascade Delete,SQL就会告诉我FK将导致多个级联路径。我的印象是,仅当多个FK表示SAME表时,才应用多个级联路径。在这种情况下,为什么会出现多个级联路径错误?

PS此时的表关系将很难更改,因此,简单地告诉我更改表结构将无济于事,谢谢。

取消 提交回答
全部回答(1)
  • 心有灵_夕
    2019-12-29 13:18:12

    该消息表示,如果删除父记录,则有两条路径可导致所有可删除的GrandChild记录。

    修复:删除FK中的ON DELETE CASCADE选项,并为ChildX表创建INSTEAD OF DELETE触发器,删除所有子记录,然后childX记录自己。

    0 0
相关问答

4

回答

Spark 【问答合集】

社区小助手 2019-05-29 14:13:40 123703浏览量 回答数 4

17

回答

【大咖问答】对话PostgreSQL 中国社区发起人之一,阿里云数据库高级专家 德哥

阿里ACE 彭飞 2019-07-10 09:36:10 967054浏览量 回答数 17

145

回答

【新手入门】云服务器linux使用手册

fanyue88888 2012-11-26 17:14:18 157079浏览量 回答数 145

8

回答

OceanBase 使用动画(持续更新)

mq4096 2019-02-20 17:16:36 333863浏览量 回答数 8

38

回答

[@饭娱咖啡][¥20]对于慢sql有没有什么比较实用的诊断和处理方法?

江小白太白 2018-10-30 18:47:38 141657浏览量 回答数 38

22

回答

爬虫数据管理【问答合集】

我是管理员 2018-08-10 16:37:41 146778浏览量 回答数 22

2

回答

mySQL数据库报错You have an error in your SQL syntax

落地花开啦 2016-02-14 16:09:24 126457浏览量 回答数 2

8

回答

flink sql 支持checkpoints吗?

游客izljdlkgbdwfc 2019-07-10 17:46:37 121148浏览量 回答数 8

38

回答

安全组详解,新手必看教程

我的中国 2017-11-30 15:23:46 256864浏览量 回答数 38

21

回答

请教一下数据量有100万条左右要什么配置?

易网网络 2013-03-27 15:18:02 192334浏览量 回答数 21
0
文章
732
问答
推荐问答
相关电子书
更多
文娱运维技术
立即下载
《SaaS模式云原生数据仓库应用场景实践》
立即下载
《看见新力量:二》电子书
立即下载