mysql處理添加外鍵時(shí)提示error 150 問題的解決方法
像這種不能創(chuàng)建一個(gè).frm 文件的報(bào)錯(cuò)好像暗示著操作系統(tǒng)的文件的權(quán)限錯(cuò)誤或者其它原因,但實(shí)際上,這些都不是的,事實(shí)上,這個(gè)mysql報(bào)錯(cuò)已經(jīng)被報(bào)告是一個(gè)mysql本身的bug并出現(xiàn)在mysql 開發(fā)者列表當(dāng)中很多年了,然而這似乎又是一種誤導(dǎo)。
在很多實(shí)例中,這種錯(cuò)誤的發(fā)生都是因?yàn)閙ysql一直以來都不能很好的支持的關(guān)系的問題, 更不幸的是它也并沒有指明到底是哪一個(gè)問題會(huì)導(dǎo)致上面那種錯(cuò)誤,下面我把導(dǎo)致這個(gè)可怕 的150錯(cuò)誤的常見原因列出來了,并且我以可能性的大小作了排序
已知的原因:
1, 兩個(gè)字段的類型或者大小不嚴(yán)格匹配,例如,如果一個(gè)是INT(10), 那么外鍵也必須設(shè)置成INT(10), 而不是 INT(11) 也不能是 TINYINT. 你得使用 SHOW 命令來查看字段的大小,因?yàn)橐恍┎樵優(yōu)g覽器有時(shí)候把 int(10) 和int(11) 都顯示為integer。另外,你還必須確定兩個(gè)字段是否一個(gè)為 SIGNED,而另一個(gè)又是UNSIGNED, 這兩字段必須嚴(yán)格地一致匹配,更多關(guān)于signed 和 unsigned 的信息,請(qǐng)參閱:http://www.verysimple.com/blog/?p=57
2, 你試圖引用的其中一個(gè)外鍵沒有建立起索引,或者不是一個(gè)primary key , 如果其中一個(gè)不是primary key 的放,你必須為它創(chuàng)建一個(gè)索引。
3, 外鍵的名字是一個(gè)已經(jīng)存在的一個(gè)鍵值了,這個(gè)時(shí)候,你應(yīng)該檢查你的數(shù)據(jù)庫以確保外健名字是唯一的,或者你在鍵名后面加上幾個(gè)隨機(jī)的字符以測(cè)試是否是這個(gè)原因。
4, 其中一個(gè)或者兩個(gè)表是MyISAM引擎的表,若想要使用外鍵約束,必須是InnoDB引擎,(實(shí)際上,如果兩個(gè)表都是MyISAM 引擎的,這個(gè)錯(cuò)誤根本不會(huì)發(fā)生,但也不會(huì)產(chǎn)生外鍵),你可以通過查詢?yōu)g覽器來設(shè)置表的引擎類型
5, 你可能設(shè)置了ON DELETE SET NULL, 但是相關(guān)的鍵的字段又設(shè)置成了NOTS NULL 值。你可能通過修改cascade 的屬性值或者把字段屬性設(shè)置成 allow null 來搞定這個(gè)bug.
6, 請(qǐng)確定你的Charset 和 Collate 選項(xiàng)在表級(jí)和字段級(jí)上的一致
7, 你可能設(shè)置為外鍵設(shè)置了一個(gè)默認(rèn)值,如 default=0
8, 在這個(gè)關(guān)系里面,其中的一個(gè)字段是一個(gè)混合鍵值中的一個(gè),它沒有自己獨(dú)立的索引,這時(shí),你必須為它創(chuàng)建一個(gè)獨(dú)立的索引。
9, ALTER 聲明中有語法錯(cuò)誤
1、外鍵的引用類型不一樣,主鍵是int外鍵是char
2、找不到主表中 引用的列
3、主鍵和外鍵的字符編碼不一致
4.還有要建立外鍵的話,要先建立索引。沒有建立索引也會(huì)出錯(cuò)。
我的問題解決方案是在sql后面加上了如下句話,ok!成功導(dǎo)入腳本
ENGINE=INNODB DEFAULT CHARSET=utf8;
charset對(duì)應(yīng)的換成你的主鍵表的字符集!
相關(guān)文章
MySQL如何快速的創(chuàng)建千萬級(jí)測(cè)試數(shù)據(jù)
這篇文章主要給大家介紹了關(guān)于MySQL如何快速的創(chuàng)建千萬級(jí)測(cè)試數(shù)據(jù)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用MySQL具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05
MySQL?InnoDB?存儲(chǔ)引擎的底層邏輯架構(gòu)
這篇文章主要為大家介紹了MySQL?InnoDB?存儲(chǔ)引擎的底層邏輯架構(gòu)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09
MySQL分表自動(dòng)化創(chuàng)建的實(shí)現(xiàn)方案
在數(shù)據(jù)庫應(yīng)用場(chǎng)景中,隨著數(shù)據(jù)量的不斷增長(zhǎng),單表存儲(chǔ)數(shù)據(jù)可能會(huì)面臨性能瓶頸,例如查詢、插入、更新等操作的效率會(huì)逐漸降低,分表是一種有效的優(yōu)化策略,它將數(shù)據(jù)分散存儲(chǔ)在多個(gè)表中,從而提高數(shù)據(jù)庫的性能和可維護(hù)性,本文介紹了MySQL分表自動(dòng)化創(chuàng)建的實(shí)現(xiàn)方案2025-01-01
php+mysql prepare 與普通查詢的性能對(duì)比實(shí)例講解
prepare可以解決大訪問量的網(wǎng)站給數(shù)據(jù)庫服務(wù)器所帶來的負(fù)載和開銷,本文章通過實(shí)例向大家介紹預(yù)查詢prepare與普通查詢的性能對(duì)比,需要的朋友可以參考一下2016-11-11
MySQL解決數(shù)據(jù)導(dǎo)入導(dǎo)出含有外鍵的方案
這篇文章主要介紹了MySQL解決數(shù)據(jù)導(dǎo)入導(dǎo)出含有外鍵的情況,文中通過圖文結(jié)合的方式給大家講解的非常詳細(xì),對(duì)大家解決問題有一定的幫助,需要的朋友可以參考下2024-11-11

