刪除MySQL中所有表的外鍵的兩種方法
方法一:
原理
查詢schema中所有外鍵名稱然后拼接生成刪除語(yǔ)句
第一步:
SELECT CONCAT('ALTER TABLE ',TABLE_SCHEMA,'.',TABLE_NAME,' DROP FOREIGN KEY ',CONSTRAINT_NAME,' ;') FROM information_schema.TABLE_CONSTRAINTS c WHERE c.TABLE_SCHEMA='數(shù)據(jù)庫(kù)名' AND c.CONSTRAINT_TYPE='FOREIGN KEY';
第二步:
將執(zhí)行第一步得到的SQL語(yǔ)句拷貝到命令行中執(zhí)行,就會(huì)刪除所有的外鍵了。
方法二
-- 禁用外鍵約束 SET FOREIGN_KEY_CHECKS = 0 -- 啟用外鍵約束 SET FOREIGN_KEY_CHECKS = 1;
由于FOREIGN_KEY_CHECKS是基于session的,當(dāng)關(guān)閉了session重新建立連接,這個(gè)變量就會(huì)恢復(fù)默認(rèn)值,也就是開(kāi)啟外鍵約束,當(dāng)然我們也可以全局的FOREIGN_KEY_CHECKS變量。
SET GLOBAL FOREIGN_KEY_CHECKS = 0; 或者: SET @@GLOBAL.FOREIGN_KEY_CHECKS = 0;
修改完成后,可以使用下面命令查看修改后的結(jié)果:
SELECT @@FOREIGN_KEY_CHECKS;
到此這篇關(guān)于刪除MySQL中所有表的外鍵的兩種方法的文章就介紹到這了,更多相關(guān)刪除MySQL所有外鍵內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySql獲取某個(gè)字段存在于哪個(gè)表的sql語(yǔ)句
本文為大家詳細(xì)介紹下通過(guò)MySql查詢某個(gè)字段所在表是哪一個(gè),具體的sql語(yǔ)句如下,感興趣的朋友可以參考下,希望對(duì)大家有所幫助2013-07-07MySQL海量數(shù)據(jù)(2億級(jí)表字段)無(wú)損更新方案
在大型互聯(lián)網(wǎng)應(yīng)用中,數(shù)據(jù)表動(dòng)輒達(dá)到億級(jí)規(guī)模,當(dāng)需要對(duì)生產(chǎn)環(huán)境中的海量表進(jìn)行字段更新時(shí),如何在不影響業(yè)務(wù)正常讀寫的情況下完成任務(wù),是每個(gè)DBA和開(kāi)發(fā)者都會(huì)面臨的挑戰(zhàn),本文將以一個(gè)真實(shí)案例詳細(xì)講解四種漸進(jìn)式更新方案及其實(shí)現(xiàn)原理,需要的朋友可以參考下2025-04-04MySQL之FIND_IN_SET()的用法及說(shuō)明
這篇文章主要介紹了MySQL之FIND_IN_SET()的用法及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01MySQL安裝提示配置信息已損壞請(qǐng)聯(lián)系技術(shù)人員
為了重新安裝MySql,看別人的博客說(shuō)在注冊(cè)表中搜索mysql,全部刪除。再安裝時(shí)提示配置信息已損壞,遇到這個(gè)問(wèn)題怎么處理呢,下面小編給大家?guī)?lái)了詳細(xì)解決方法,感興趣的朋友一起看看吧2023-01-01記錄無(wú)法安裝mysql-Invalid GPG Key from file:/etc/pki/rpm-gpg/RPM-G
在aliyun上安裝MySQL時(shí)由于上次錯(cuò)誤卸載mysql 導(dǎo)致校驗(yàn)文件出問(wèn)題。下面小編給大家分享記錄無(wú)法安裝mysql-Invalid GPG Key from file:/etc/pki/rpm-gpg/RPM-GPG-KEY-mysql的解決方法,需要的朋友參考下吧2017-01-01select?into?from和insert?into?select的區(qū)別舉例詳解
這篇文章主要介紹了SQL中的SELECT?INTO和INSERT?INTO?SELECT兩種語(yǔ)句的區(qū)別和用法,SELECT?INTO用于創(chuàng)建新表并復(fù)制數(shù)據(jù)到新表中,而INSERT?INTO?SELECT用于將數(shù)據(jù)從一個(gè)表插入到已存在的另一個(gè)表中,需要的朋友可以參考下2025-03-03MySQL?UPDATE多表關(guān)聯(lián)更新的實(shí)現(xiàn)示例
MySQL可以基于多表查詢更新數(shù)據(jù),本文主要介紹了MySQL?UPDATE多表關(guān)聯(lián)更新的實(shí)現(xiàn)示例,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-08-08關(guān)于MySQL數(shù)據(jù)遷移--data目錄直接替換注意事項(xiàng)的詳解
本篇文章是對(duì)關(guān)于MySQL數(shù)據(jù)遷移--data目錄直接替換的注意事項(xiàng)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06