mysql創(chuàng)建外鍵報(bào)錯(cuò)的原因及解決(can't?not?create?table)
最近在玩數(shù)據(jù)庫(kù)的時(shí)候,偶爾會(huì)有外鍵創(chuàng)建不成功的時(shí)候,于是上網(wǎng)查閱資料,整合自己的理解有了以下這篇文章:
mysql創(chuàng)建外鍵不成功的原因及處理方法
第一種情況
外鍵的字段與關(guān)聯(lián)的字段的類型不匹配(包括編碼格式的不匹配):

兩個(gè)不同的表格(一個(gè)是record(借書記錄表),一個(gè)是reader(讀者信息表)):然后關(guān)聯(lián)的兩個(gè)readerid 字段要保持一致,包括長(zhǎng)度,類型要保持一致。
然后是編碼格式

兩個(gè)表的引擎,字符集要保持一致,這樣才能關(guān)聯(lián)成功;
另外,若讀者對(duì)表的設(shè)計(jì)有unsign與sign的設(shè)定,要注意設(shè)定的外鍵的字段與關(guān)聯(lián)的字段也要保持一致。
第二種情況
外鍵的名字是一個(gè)已經(jīng)存在的鍵值,要保證名字的唯一,如下:

一般創(chuàng)建外鍵名字的時(shí)候是用 表名+FK+數(shù)字來(lái)區(qū)別于其他外鍵 ,如上表是record表,創(chuàng)建的外鍵名字是recordFK1,recordFK2等等.
可以嘗試,在外鍵名字后面加幾個(gè)數(shù)字判斷是否是這個(gè)引起的錯(cuò)誤。
第三種情況
mysql引擎引起的外鍵創(chuàng)建不能保存或者不能發(fā)揮作用的情況,mysql一般的默認(rèn)引擎是myisam,而myisam是不能創(chuàng)建外鍵的。
具體的判斷方法以及問(wèn)題處理方法大家可以去博主的另外一篇博客查看:mysql創(chuàng)建外鍵無(wú)法保存的原因及處理
第四種情況
試圖創(chuàng)建的一個(gè)外鍵沒(méi)有建立起索引,或者不是一個(gè)primary key 并且如果其中不是一個(gè)primary key,你必須為他創(chuàng)建一個(gè)索引。
第五種情況
外鍵的動(dòng)作設(shè)置成on delete set null 或者 on update set null,但是在關(guān)聯(lián)的表的字段又設(shè)置的no null,導(dǎo)致沖突:


(這張表是正確操作)
而錯(cuò)誤操作是, 外鍵設(shè)定了 當(dāng)admin的 username更新時(shí),這張表(traffic)會(huì)跟著把關(guān)聯(lián)的字段設(shè)為null
而在traffic這張表的對(duì)應(yīng) username字段(本來(lái)應(yīng)該null的),但是卻設(shè)定了 不允許為空,引起的沖突。
解決方法:設(shè)置為CASCADE級(jí)聯(lián)更新,或者修改為允許為空。
第六種情況
在navicat設(shè)定的表格主鍵中 有 主鍵1,主鍵2,主鍵3,的區(qū)別,主鍵1不能被級(jí)聯(lián)更新(刪除)(CASCADE)
第七種情況
外鍵存在默認(rèn)值,引起的沖突
第八種情況
混合鍵值缺少索引引起的情況,需要為他單獨(dú)申請(qǐng)索引
第九種情況
在sql語(yǔ)句創(chuàng)建外鍵時(shí),create 或者 alter語(yǔ)法錯(cuò)誤
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
在win10系統(tǒng)下安裝Mysql 5.7.17圖文教程
因?yàn)橄胍诠倦娔X上安裝Mysql,于是到官網(wǎng)上下載了最新版本的Mysql-5.7.17,其實(shí)安裝方法也很簡(jiǎn)單,下面小編把安裝過(guò)程分享到腳本之家平臺(tái)供大家參考2017-03-03
MySQL Packet for query is too large 問(wèn)題及解決方法
這篇文章主要介紹了MySQL Packet for query is too large 問(wèn)題及解決方法,需要的朋友可以參考下2018-05-05
Mysql中find_in_set()函數(shù)用法詳解以及使用場(chǎng)景
前幾天在sql查詢的時(shí)候,想要判斷數(shù)據(jù)庫(kù)中表的某一列中的值是否在List集合中,接觸到了find_in_set的使用,用起來(lái)方便快捷,下面這篇文章主要給大家介紹了關(guān)于Mysql中find_in_set()函數(shù)用法詳解以及使用場(chǎng)景的相關(guān)資料,需要的朋友可以參考下2023-03-03
如何在Windows中運(yùn)行多個(gè)MySQL實(shí)例詳解
這篇文章主要給大家介紹了關(guān)于如何在Windows中運(yùn)行多個(gè)MySQL實(shí)例的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用MySQL具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09

