MySQL刪除表的時(shí)候忽略外鍵約束的簡(jiǎn)單實(shí)現(xiàn)
刪除表不是特別常用,特別是對(duì)于存在外鍵關(guān)聯(lián)的表,刪除更得小心。但是在開發(fā)過程中,發(fā)現(xiàn)Schema設(shè)計(jì)的有問題而且要?jiǎng)h除現(xiàn)有的數(shù)據(jù)庫(kù)中所有的表來重新創(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è)表(父表)之前必須先刪除具有外鍵的表(子表)。也就是說,刪除表的過程需要和創(chuàng)建表的過程一致。
但是這往往不可接受,一方面如果表太多了,手動(dòng)排序有點(diǎn)不可接受;另一方面,現(xiàn)在還沒有自動(dòng)的工具對(duì)進(jìn)行排序(其實(shí)也不是不能實(shí)現(xiàn))。因此,MySQL中提供了一個(gè)變量FOREIGN_KEY_CHECKS來設(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ān)系,這個(gè)變量是基于Session的,也就是說,當(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í)候忽略外鍵約束的簡(jiǎn)單實(shí)現(xiàn)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- MySQL刪除表數(shù)據(jù)、清空表命令詳解(truncate、drop、delete區(qū)別)
- MySQL刪除表操作實(shí)現(xiàn)(delete、truncate、drop的區(qū)別)
- MySQL如何刪除表中的數(shù)據(jù)
- 為什么MySQL 刪除表數(shù)據(jù) 磁盤空間還一直被占用
- MySQL刪除表的三種方式(小結(jié))
- mysql查找刪除表中重復(fù)數(shù)據(jù)方法總結(jié)
- MySql刪除表中一行的實(shí)操方法
- mysql創(chuàng)建刪除表的實(shí)例詳解
- MySQL刪除表數(shù)據(jù)的方法
- MySQL命令行刪除表中的一個(gè)字段
- MySQL刪除表三種操作及delete、truncate、drop語(yǔ)句的區(qū)別
相關(guān)文章
淺談MySQL存儲(chǔ)引擎選擇 InnoDB與MyISAM的優(yōu)缺點(diǎn)分析
MyISAM 是MySQL中默認(rèn)的存儲(chǔ)引擎,一般來說不是有太多人關(guān)心這個(gè)東西。決定使用什么樣的存儲(chǔ)引擎是一個(gè)很tricky的事情,但是還是值我們?nèi)パ芯恳幌?,這里的文章只考慮 MyISAM 和InnoDB這兩個(gè),因?yàn)檫@兩個(gè)是最常見的2013-06-06
詳細(xì)聊聊關(guān)于Mysql聯(lián)合查詢的那些事兒
聯(lián)合查詢union將多次查詢(多條select語(yǔ)句)的結(jié)果,在字段數(shù)相同的情況下,在記錄的層次上進(jìn)行拼接,這篇文章主要給大家介紹了關(guān)于Mysql聯(lián)合查詢的那些事兒,需要的朋友可以參考下2021-10-10
FROM_UNIXTIME 格式化MYSQL時(shí)間戳函數(shù)
對(duì)MYSQL沒有進(jìn)行過深入的研究,基礎(chǔ)知識(shí)匱乏,一遇到問題只能手冊(cè),看來要把MYSQL的學(xué)習(xí)安排進(jìn)時(shí)間表了。2011-04-04
Linux CentOS MySQL數(shù)據(jù)庫(kù)安裝配置教程
這篇文章主要為大家詳細(xì)介紹了Linux CentOS MySQL數(shù)據(jù)庫(kù)的安裝配置教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05
mysql數(shù)據(jù)庫(kù)提權(quán)的三種方法
文介紹了MySQL數(shù)據(jù)庫(kù)的三種提權(quán)方法:UDF提權(quán)、MOF提權(quán)和啟動(dòng)項(xiàng)提權(quán),同時(shí)列出了一些常見數(shù)據(jù)庫(kù)及其默認(rèn)端口,下面就來介紹一下,感興趣的可以了解一下2024-09-09

