當前位置:首頁 > 綜合 > 正文

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删除級聯。測試例的全部内容,希望文章能夠幫你解決所遇到的問題。

如果覺得真正的電腦專家網站内容還不錯,歡迎将真正的電腦專家推薦給好友。

你可能想看:

有話要說...

取消
掃碼支持 支付碼