濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > MySQL刪除表的時(shí)候忽略外鍵約束的簡(jiǎn)單實(shí)現(xiàn)

MySQL刪除表的時(shí)候忽略外鍵約束的簡(jiǎn)單實(shí)現(xiàn)

熱門標(biāo)簽:dq8 全地圖標(biāo)注 遂寧400電話申請(qǐng) 永州智能外呼系統(tǒng) 哈爾濱云外呼系統(tǒng)運(yùn)營(yíng)商 邯鄲400電話注冊(cè)辦理 南寧智能電銷機(jī)器人價(jià)格 電銷機(jī)器人市場(chǎng)價(jià) 地圖標(biāo)注直通車 趙縣地圖標(biāo)注

刪除表不是特別常用,特別是對(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í)例講解
  • 詳解MySQL 外鍵約束
  • MySQL外鍵約束常見操作方法示例【查看、添加、修改、刪除】
  • MySQL刪除有外鍵約束的表數(shù)據(jù)方法介紹
  • MySQL 關(guān)閉子表的外鍵約束檢察方法
  • MySQL外鍵約束的禁用與啟用命令
  • 詳解MySQL中的外鍵約束問題
  • MySQL創(chuàng)建數(shù)據(jù)表并建立主外鍵關(guān)系詳解
  • MySQL與Oracle數(shù)據(jù)類型對(duì)應(yīng)關(guān)系(表格形式)
  • MySQL 外鍵約束和表關(guān)系相關(guān)總結(jié)

標(biāo)簽:中衛(wèi) 定西 張家界 阿里 鄂州 南寧 浙江 上海

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL刪除表的時(shí)候忽略外鍵約束的簡(jiǎn)單實(shí)現(xiàn)》,本文關(guān)鍵詞  MySQL,刪除,表,的,時(shí)候,忽略,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL刪除表的時(shí)候忽略外鍵約束的簡(jiǎn)單實(shí)現(xiàn)》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于MySQL刪除表的時(shí)候忽略外鍵約束的簡(jiǎn)單實(shí)現(xiàn)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    瑞昌市| 漯河市| 怀集县| 中牟县| 赞皇县| 彝良县| 精河县| 荥经县| 铜陵市| 璧山县| 衡南县| 宜章县| 留坝县| 天等县| 鸡东县| 新宾| 南雄市| 阿城市| 修水县| 五原县| 都兰县| 嘉禾县| 江山市| 台东市| 德化县| 承德市| 济宁市| 岗巴县| 孟津县| 银川市| 长白| 鄂托克旗| 怀化市| 包头市| 儋州市| 西昌市| 青州市| 海安县| 恭城| 伊川县| 麻栗坡县|