MySQL刪除表的時候忽略外鍵約束的簡單實現(xiàn)
刪除表不是特別常用,特別是對于存在外鍵關(guān)聯(lián)的表,刪除更得小心。但是在開發(fā)過程中,發(fā)現(xiàn)Schema設(shè)計的有問題而且要刪除現(xiàn)有的數(shù)據(jù)庫中所有的表來重新創(chuàng)建也是常有的事情;另外在測試的時候,也有需要重新創(chuàng)建數(shù)據(jù)庫的所有表。當(dāng)然很多自動化工具也可以做這樣的事情。
刪除表的時候有時會遇到這樣的錯誤消息:
ERROR 1217 (23000): Cannot delete or update a parent row: a foreign key constraint fails
這是因為你嘗試刪除的表中的字段被用作了其他表的外鍵,因此在刪除這個表(父表)之前必須先刪除具有外鍵的表(子表)。也就是說,刪除表的過程需要和創(chuàng)建表的過程一致。
但是這往往不可接受,一方面如果表太多了,手動排序有點不可接受;另一方面,現(xiàn)在還沒有自動的工具對進(jìn)行排序(其實也不是不能實現(xiàn))。因此,MySQL中提供了一個變量FOREIGN_KEY_CHECKS來設(shè)置是否在必要的時候檢查外鍵約束。
一般比較推薦這樣做:
首先,自動生成所有的DROP語句,將其中的MyDatabaseName替換成你的數(shù)據(jù)庫名稱:
SELECT concat('DROP TABLE IF EXISTS ', table_name, ';') FROM information_schema.tables WHERE table_schema = 'MyDatabaseName';
然后,在生成的代碼前后添加下面設(shè)置FOREIGN_KEY_CHECKS變量的語句:
SET FOREIGN_KEY_CHECKS = 0 -- DROP語句 SET FOREIGN_KEY_CHECKS = 1;
不過,要是忘記了最后一句也沒太大關(guān)系,這個變量是基于Session的,也就是說,當(dāng)你關(guān)閉了客戶端,重新建立連接的時候,這個變量會恢復(fù)默認(rèn)值。如果需要在全局范圍內(nèi)不檢查外鍵約束(這種情況會比較少吧),可以這樣做:
SET GLOBAL FOREIGN_KEY_CHECKS = 0;
或者
set @@global.FOREIGN_KEY_CHECKS = 0;
以上這篇MySQL刪除表的時候忽略外鍵約束的簡單實現(xiàn)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
- MySQL刪除表數(shù)據(jù)、清空表命令詳解(truncate、drop、delete區(qū)別)
- MySQL刪除表操作實現(xiàn)(delete、truncate、drop的區(qū)別)
- MySQL如何刪除表中的數(shù)據(jù)
- 為什么MySQL 刪除表數(shù)據(jù) 磁盤空間還一直被占用
- MySQL刪除表的三種方式(小結(jié))
- mysql查找刪除表中重復(fù)數(shù)據(jù)方法總結(jié)
- MySql刪除表中一行的實操方法
- mysql創(chuàng)建刪除表的實例詳解
- MySQL刪除表數(shù)據(jù)的方法
- MySQL命令行刪除表中的一個字段
- MySQL刪除表三種操作及delete、truncate、drop語句的區(qū)別
相關(guān)文章
MyBatis-Plus查詢不到數(shù)據(jù)但使用SQL可以查詢到數(shù)據(jù)的問題排查解決
在使用MyBatis-Plus時,有時會出現(xiàn)查詢不到數(shù)據(jù)的問題,而直接執(zhí)行SQL卻能查詢到數(shù)據(jù),本文將介紹如何排查和解決這一問題,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-09-09MySQL中TIMESTAMP類型返回日期時間數(shù)據(jù)中帶有T的解決
這篇文章主要介紹了MySQL中TIMESTAMP類型返回日期時間數(shù)據(jù)中帶有T的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-12-12MySQL server has gone away錯誤提示解決方法
今天遇到類似的情景,MySQL只是冷冷的說:MySQL server has gone away。2008-11-11