欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql處理添加外鍵時提示error 150 問題的解決方法

 更新時間:2011年11月15日 01:56:52   作者:  
當(dāng)你試圖在mysql中創(chuàng)建一個外鍵的時候,這個出錯會經(jīng)常發(fā)生,這是非常令人沮喪的

像這種不能創(chuàng)建一個.frm 文件的報錯好像暗示著操作系統(tǒng)的文件的權(quán)限錯誤或者其它原因,但實(shí)際上,這些都不是的,事實(shí)上,這個mysql報錯已經(jīng)被報告是一個mysql本身的bug并出現(xiàn)在mysql 開發(fā)者列表當(dāng)中很多年了,然而這似乎又是一種誤導(dǎo)。

在很多實(shí)例中,這種錯誤的發(fā)生都是因?yàn)閙ysql一直以來都不能很好的支持的關(guān)系的問題, 更不幸的是它也并沒有指明到底是哪一個問題會導(dǎo)致上面那種錯誤,下面我把導(dǎo)致這個可怕 的150錯誤的常見原因列出來了,并且我以可能性的大小作了排序

已知的原因:

1, 兩個字段的類型或者大小不嚴(yán)格匹配,例如,如果一個是INT(10), 那么外鍵也必須設(shè)置成INT(10), 而不是 INT(11) 也不能是 TINYINT. 你得使用 SHOW 命令來查看字段的大小,因?yàn)橐恍┎樵優(yōu)g覽器有時候把 int(10) 和int(11) 都顯示為integer。另外,你還必須確定兩個字段是否一個為 SIGNED,而另一個又是UNSIGNED, 這兩字段必須嚴(yán)格地一致匹配,更多關(guān)于signed 和 unsigned 的信息,請參閱:http://www.verysimple.com/blog/?p=57

2, 你試圖引用的其中一個外鍵沒有建立起索引,或者不是一個primary key , 如果其中一個不是primary key 的放,你必須為它創(chuàng)建一個索引。

3, 外鍵的名字是一個已經(jīng)存在的一個鍵值了,這個時候,你應(yīng)該檢查你的數(shù)據(jù)庫以確保外健名字是唯一的,或者你在鍵名后面加上幾個隨機(jī)的字符以測試是否是這個原因。

4, 其中一個或者兩個表是MyISAM引擎的表,若想要使用外鍵約束,必須是InnoDB引擎,(實(shí)際上,如果兩個表都是MyISAM 引擎的,這個錯誤根本不會發(fā)生,但也不會產(chǎn)生外鍵),你可以通過查詢?yōu)g覽器來設(shè)置表的引擎類型

5, 你可能設(shè)置了ON DELETE SET NULL, 但是相關(guān)的鍵的字段又設(shè)置成了NOTS NULL 值。你可能通過修改cascade 的屬性值或者把字段屬性設(shè)置成 allow null 來搞定這個bug.

6, 請確定你的Charset 和 Collate 選項(xiàng)在表級和字段級上的一致

7, 你可能設(shè)置為外鍵設(shè)置了一個默認(rèn)值,如 default=0

8, 在這個關(guān)系里面,其中的一個字段是一個混合鍵值中的一個,它沒有自己獨(dú)立的索引,這時,你必須為它創(chuàng)建一個獨(dú)立的索引。

9, ALTER 聲明中有語法錯誤

1、外鍵的引用類型不一樣,主鍵是int外鍵是char

2、找不到主表中 引用的列

3、主鍵和外鍵的字符編碼不一致

4.還有要建立外鍵的話,要先建立索引。沒有建立索引也會出錯。

我的問題解決方案是在sql后面加上了如下句話,ok!成功導(dǎo)入腳本
ENGINE=INNODB DEFAULT CHARSET=utf8;
charset對應(yīng)的換成你的主鍵表的字符集!

相關(guān)文章

  • mysql中的隔離性原理詳解

    mysql中的隔離性原理詳解

    這篇文章主要介紹了mysql隔離性的原理,多版本并發(fā)控制(MVCC)是一種用來解決?讀-寫沖突?的無鎖并發(fā)控制,為事務(wù)分配單向增長的事務(wù)ID,為每個修改保存一個版本,版本與事務(wù)ID關(guān)聯(lián),讀操作只讀該事務(wù)開始前的數(shù)據(jù)庫的快照,需要的朋友可以參考下
    2023-08-08
  • MySQL查詢排序與查詢聚合函數(shù)用法分析

    MySQL查詢排序與查詢聚合函數(shù)用法分析

    這篇文章主要介紹了MySQL查詢排序與查詢聚合函數(shù)用法,結(jié)合實(shí)例形式分析了MySQL查詢結(jié)果排序以及查詢聚合函數(shù)相關(guān)使用技巧,需要的朋友可以參考下
    2019-11-11
  • Mysql中的CHECK約束特性詳解

    Mysql中的CHECK約束特性詳解

    這篇文章主要介紹了Mysql中的CHECK約束特性詳解的相關(guān)資料,講解的十分淺顯易懂,這里推薦給大家,需要的朋友可以參考下
    2022-08-08
  • MySQL該如何判斷不為空詳析

    MySQL該如何判斷不為空詳析

    在MySQL數(shù)據(jù)庫中,在不同的情形下,空值往往代表不同的含義,這是MySQL數(shù)據(jù)庫的一種特性,下面這篇文章主要給大家介紹了關(guān)于MySQL該如何判斷不為空的相關(guān)資料,需要的朋友可以參考下
    2023-02-02
  • mysql大批量插入數(shù)據(jù)的正確解決方法

    mysql大批量插入數(shù)據(jù)的正確解決方法

    這篇文章主要介紹了mysql大批量插入數(shù)據(jù)的正確做法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-09-09
  • mysql中模糊查詢的四種用法介紹

    mysql中模糊查詢的四種用法介紹

    這篇文章主要介紹了mysql中模糊查詢的四種用法,需要的朋友可以參考下
    2014-03-03
  • MySQL索引下推詳細(xì)

    MySQL索引下推詳細(xì)

    這篇文章主要介紹MySQL索引下推,索引下推(ICP)是針對MySQL使用索引從表中檢索數(shù)據(jù)行的情況的優(yōu)化。下面就來介紹相關(guān)資料,需要的朋友可以參考一下
    2021-10-10
  • Mac上安裝MySQL過程分享

    Mac上安裝MySQL過程分享

    這篇文章主要介紹了Mac上安裝MySQL過程分享,本文共分4步完成,簡單易懂,需要的朋友可以參考下
    2014-11-11
  • MySQL數(shù)據(jù)庫show processlist指令使用解析

    MySQL數(shù)據(jù)庫show processlist指令使用解析

    這篇文章主要介紹了MySQL數(shù)據(jù)庫show processlist指令使用解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-11-11
  • MySQL8.0中你必須要知道的索引新特性

    MySQL8.0中你必須要知道的索引新特性

    MySQL8.0索引新特性,支持降序索引,降序索引以降序存儲鍵值,下面這篇文章主要給大家介紹了關(guān)于MySQL8.0中你必須要知道的索引新特性的相關(guān)資料,需要的朋友可以參考下
    2022-11-11

最新評論