当前位置:首页 > 综合 > 正文

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在表创建查询中未正确使用?我不知道…

总结

以上是真正的电脑专家为你收集整理的MySQL删除级联。测试例的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得真正的电脑专家网站内容还不错,欢迎将真正的电脑专家推荐给好友。

有话要说...

取消
扫码支持 支付码