国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

MySQL刪除表的時候忽略外鍵約束的簡單實現

2024-07-24 13:12:34
字體:
來源:轉載
供稿:網友

刪除表不是特別常用,特別是對于存在外鍵關聯的表,刪除更得小心。但是在開發過程中,發現Schema設計的有問題而且要刪除現有的數據庫中所有的表來重新創建也是常有的事情;另外在測試的時候,也有需要重新創建數據庫的所有表。當然很多自動化工具也可以做這樣的事情。

刪除表的時候有時會遇到這樣的錯誤消息:

ERROR 1217 (23000): Cannot delete or update a parent row: a foreign key constraint fails

這是因為你嘗試刪除的表中的字段被用作了其他表的外鍵,因此在刪除這個表(父表)之前必須先刪除具有外鍵的表(子表)。也就是說,刪除表的過程需要和創建表的過程一致。

但是這往往不可接受,一方面如果表太多了,手動排序有點不可接受;另一方面,現在還沒有自動的工具對進行排序(其實也不是不能實現)。因此,MySQL中提供了一個變量FOREIGN_KEY_CHECKS來設置是否在必要的時候檢查外鍵約束。

一般比較推薦這樣做:

首先,自動生成所有的DROP語句,將其中的MyDatabaseName替換成你的數據庫名稱:

SELECT concat('DROP TABLE IF EXISTS ', table_name, ';')FROM information_schema.tablesWHERE table_schema = 'MyDatabaseName';

然后,在生成的代碼前后添加下面設置FOREIGN_KEY_CHECKS變量的語句:

SET FOREIGN_KEY_CHECKS = 0-- DROP語句SET FOREIGN_KEY_CHECKS = 1;

不過,要是忘記了最后一句也沒太大關系,這個變量是基于Session的,也就是說,當你關閉了客戶端,重新建立連接的時候,這個變量會恢復默認值。如果需要在全局范圍內不檢查外鍵約束(這種情況會比較少吧),可以這樣做:

SET GLOBAL FOREIGN_KEY_CHECKS = 0;

或者

set @@global.FOREIGN_KEY_CHECKS = 0;

以上這篇MySQL刪除表的時候忽略外鍵約束的簡單實現就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 尚志市| 云和县| 桐梓县| 湖南省| 平乡县| 金昌市| 南乐县| 科技| 达尔| 德格县| 临沧市| 平南县| 昂仁县| 天水市| 若羌县| 洛宁县| 石城县| 文化| 措勤县| 宁明县| 汾阳市| 阿克陶县| 广德县| 甘孜| 宜昌市| 大同县| 彭山县| 商城县| 吴忠市| 卢湾区| 吐鲁番市| 永平县| 齐河县| 邓州市| 平乐县| 重庆市| 宜兰县| 清原| 凉山| 壤塘县| 安国市|