mysql數(shù)據(jù)庫(kù)錯(cuò)誤合集

一、SQL錯(cuò)誤(1071) : : Specified key was too long;max key lengthis 767 bytes

創(chuàng)建表的時(shí)候,若主鍵索引或聯(lián)合索引大小超過默認(rèn)值,則無法創(chuàng)建,修改mysql配置:

? ? ?? set global innodb_large_prefix = ON;(限制值會(huì)增加到3072)

? ? ?? 系統(tǒng)變量innodb_large_prefix開啟了,則對(duì)于使用DYNAMIC或COMPRESSED行格式的InnoDB表,索引鍵前綴限制為3072字節(jié)。如果禁用innodb_large_prefix,不管是什么表,索引鍵前綴限制為767字節(jié)。報(bào)錯(cuò)的那張表建立了一個(gè)varchar類型的索引,varchar(255),使用的字符集為(utf8mb4),這個(gè)指每個(gè)字符最大的字節(jié)數(shù)為4,所以很明顯 4*255 > 767。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容