如何解决MySQL删除级联测试例
答案d。当且仅当存储引擎实际支持并强制执行外键约束时,才是正确的。
如果使用创建表Engine=MyISAM
,则b。或d。是正确的。
如果使用创建表Engine=InnoDB
,则 是正确的。
注意:
仅当且仅当InnoDB才如此FOREIGN_KEY_CHECKS = 1
。如果为FOREIGN_KEY_CHECKS =
0
,则DELETE
来自父表(foo)的a 不会 从子表(foo2)中删除引用从父表中删除的行的行。
使用SHOW VARIABLES LIKE 'foreign_key_checks'
(1 = ON,0 =
OFF)的输出进行验证(正常默认值为ON。)
来自的输出SHOW CREATE TABLE foo
将显示表使用的引擎。
来自的输出SHOW VARIABLES LIKE 'storage_engine'
将显示在创建表且未指定引擎时使用的默认引擎。
解决方法
我想知道这个测试问题。我自己准备了示例并进行了测试,但是我仍然不确定答案。
具有以下内容:
CREATE TABLE foo (
id INT PRIMARY KEY AUTO_INCREMENT,name INT
)
CREATE TABLE foo2 (
id INT PRIMARY KEY AUTO_INCREMENT,foo_id INT REFERENCES foo(id) ON DELETE CASCADE
)
据我所知,答案是:
一个。 创建两个表
虽然也有:
b。 如果删除表foo2中foo_id为2的行,则表foo中id = 2的行将被自动删除
d。如果删除表foo中id = 2的行,则删除表foo2中所有foo_id = 2的行
在我的示例中,我将使用delete语法:
DELETE FROM foo WHERE id = 2;
DELETE FROM foo2 WHERE foo_id = 2;
由于某种原因,我似乎找不到表之间的任何关系,尽管看起来应该有一个关系。也许有一些MySQL设置,或者ON DELETE
CASCADE
在表创建查询中未正确使用?我不知道…
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。