MySQL刪除表的時(shí)候忽略外鍵約束的代碼案例分享
發(fā)表時(shí)間:2023-09-09 來(lái)源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]下面小編就為大家?guī)?lái)一篇MySQL刪除表的時(shí)候忽略外鍵約束的簡(jiǎn)單實(shí)現(xiàn)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧刪除表不是特別常用,特別是對(duì)于存在外鍵關(guān)聯(lián)的表,刪除更得小心。但是在開(kāi)發(fā)過(guò)程中,發(fā)現(xiàn)Schema設(shè)計(jì)的有問(wèn)題而且要?jiǎng)h除現(xiàn)有的數(shù)據(jù)庫(kù)中所有的表來(lái)重新創(chuàng)建也...
下面小編就為大家?guī)?lái)一篇
MySQL刪除表的時(shí)候忽略外鍵約束的簡(jiǎn)單實(shí)現(xiàn)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
刪除表不是特別常用,特別是對(duì)于存在外鍵關(guān)聯(lián)的表,刪除更得小心。但是在開(kāi)發(fā)過(guò)程中,發(fā)現(xiàn)Schema設(shè)計(jì)的有問(wèn)題而且要?jiǎng)h除現(xiàn)有的數(shù)據(jù)庫(kù)中所有的表來(lái)重新創(chuàng)建也是常有的事情;另外在測(cè)試的時(shí)候,也有需要重新創(chuàng)建數(shù)據(jù)庫(kù)的所有表。當(dāng)然很多自動(dòng)化工具也可以做這樣的事情。
刪除表的時(shí)候有時(shí)會(huì)遇到這樣的錯(cuò)誤消息:
ERROR 1217 (23000): Cannot delete or update a parent row: a foreign key constraint fails
這是因?yàn)槟銍L試刪除的表中的字段被用作了其他表的外鍵,因此在刪除這個(gè)表(父表)之前必須先刪除具有外鍵的表(子表)。也就是說(shuō),刪除表的過(guò)程需要和創(chuàng)建表的過(guò)程一致。
但是這往往不可接受,一方面如果表太多了,手動(dòng)排序有點(diǎn)不可接受;另一方面,現(xiàn)在還沒(méi)有自動(dòng)的工具對(duì)進(jìn)行排序(其實(shí)也不是不能實(shí)現(xiàn))。因此,MySQL中提供了一個(gè)變量FOREIGN_KEY_CHECKS來(lái)設(shè)置是否在必要的時(shí)候檢查外鍵約束。
一般比較推薦這樣做:
首先,自動(dòng)生成所有的DROP語(yǔ)句,將其中的MyDatabaseName替換成你的數(shù)據(jù)庫(kù)名稱:
SELECT concat('DROP TABLE IF EXISTS ', table_name, ';')
FROM information_schema.tables
WHERE table_schema = 'MyDatabaseName';
然后,在生成的代碼前后添加下面設(shè)置FOREIGN_KEY_CHECKS變量的語(yǔ)句:
SET FOREIGN_KEY_CHECKS = 0
-- DROP語(yǔ)句
SET FOREIGN_KEY_CHECKS = 1;
不過(guò),要是忘記了最后一句也沒(méi)太大關(guān)系,這個(gè)變量是基于Session的,也就是說(shuō),當(dāng)你關(guān)閉了客戶端,重新建立連接的時(shí)候,這個(gè)變量會(huì)恢復(fù)默認(rèn)值。如果需要在全局范圍內(nèi)不檢查外鍵約束(這種情況會(huì)比較少吧),可以這樣做:
SET GLOBAL FOREIGN_KEY_CHECKS = 0;
或者
set @@global.FOREIGN_KEY_CHECKS = 0;
以上就是MySQL刪除表的時(shí)候忽略外鍵約束的代碼實(shí)例分享的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注php中文網(wǎng)其它相關(guān)文章!
學(xué)習(xí)教程快速掌握從入門到精通的SQL知識(shí)。