五月综合激情婷婷六月,日韩欧美国产一区不卡,他扒开我内裤强吻我下面视频 ,无套内射无矿码免费看黄,天天躁,日日躁,狠狠躁

新聞動態(tài)

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

發(fā)布日期:2022-06-20 11:21 | 文章來源:gibhub

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

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

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

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

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

一般比較推薦這樣做:

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

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;

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

SET GLOBAL FOREIGN_KEY_CHECKS = 0;

或者

set @@global.FOREIGN_KEY_CHECKS = 0;

以上這篇MySQL刪除表的時候忽略外鍵約束的簡單實現(xiàn)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持本站。

美國服務器租用

版權(quán)聲明:本站文章來源標注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務器上建立鏡像,否則將依法追究法律責任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學習參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。

實時開通

自選配置、實時開通

免備案

全球線路精選!

全天候客戶服務

7x24全年不間斷在線

專屬顧問服務

1對1客戶咨詢顧問

在線
客服

在線客服:7*24小時在線

客服
熱線

400-630-3752
7*24小時客服服務熱線

關(guān)注
微信

關(guān)注官方微信
頂部