好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > MySQL刪除表的時候忽略外鍵約束的簡單實現

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

熱門標簽:dq8 全地圖標注 遂寧400電話申請 永州智能外呼系統 哈爾濱云外呼系統運營商 邯鄲400電話注冊辦理 南寧智能電銷機器人價格 電銷機器人市場價 地圖標注直通車 趙縣地圖標注

刪除表不是特別常用,特別是對于存在外鍵關聯的表,刪除更得小心。但是在開發過程中,發現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.tables
WHERE 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刪除表的時候忽略外鍵約束的簡單實現就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • MySQL外鍵約束的實例講解
  • 詳解MySQL 外鍵約束
  • MySQL外鍵約束常見操作方法示例【查看、添加、修改、刪除】
  • MySQL刪除有外鍵約束的表數據方法介紹
  • MySQL 關閉子表的外鍵約束檢察方法
  • MySQL外鍵約束的禁用與啟用命令
  • 詳解MySQL中的外鍵約束問題
  • MySQL創建數據表并建立主外鍵關系詳解
  • MySQL與Oracle數據類型對應關系(表格形式)
  • MySQL 外鍵約束和表關系相關總結

標簽:中衛 定西 張家界 阿里 鄂州 南寧 浙江 上海

巨人網絡通訊聲明:本文標題《MySQL刪除表的時候忽略外鍵約束的簡單實現》,本文關鍵詞  MySQL,刪除,表,的,時候,忽略,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL刪除表的時候忽略外鍵約束的簡單實現》相關的同類信息!
  • 本頁收集關于MySQL刪除表的時候忽略外鍵約束的簡單實現的相關信息資訊供網民參考!
  • 推薦文章