mysql5.6建立索引報錯1709問題及解決
現(xiàn)象描述
在給varchar字段建立索引時,報錯如下:
[root@localhost:(test) 13:53:27]> CREATE INDEX b_name_IDX USING BTREE ON test.b(name);ERROR 1709 (HY000): Index column size too large. The maximum column size is 767 bytes.
查看表結(jié)構(gòu):
CREATE TABLE `b` ( `name` varchar(250) DEFAULT NULL, `standardized_name` varchar(250) DEFAULT NULL, `is_reagent` int(11) NOT NULL DEFAULT '0', `is_solvent` int(11) NOT NULL DEFAULT '0', `is_catalyst` int(11) NOT NULL DEFAULT '0', `is_ligand` int(11) NOT NULL DEFAULT '0', `to_delete` int(11) DEFAULT '0', ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
原因分析
索引字段的長度大于767,或者說,使用到的字段的長度和大于767則報錯。
MySQL 5.6 中的innodb_large_prefix默認是關(guān)閉的。
在MySQL中,innodb_large_prefix 參數(shù)是一個 InnoDB 存儲引擎的配置選項。
這個參數(shù)控制是否允許使用超過767字節(jié)(或255個字符)的索引前綴。
默認情況下,在MySQL 5.6及以前版本中,InnoDB存儲引擎對索引列的最大長度限制為767字節(jié)。
對于變長數(shù)據(jù)類型如VARCHAR,這個限制包括了字符集的每個字符可能占用的字節(jié)數(shù),而不是僅僅指字符數(shù)。
例如,如果你使用的是UTF-8字符集,每個字符可能占用1到4個字節(jié),所以一個VARCHAR(255)字段的實際最大長度可能會遠小于255個字符。
當 innodb_large_prefix 設(shè)置為 ON 時,InnoDB 支持更大的索引前綴長度,最大可以達到3072字節(jié)。
這意味著你可以創(chuàng)建更長的索引,特別是對于包含大量變長數(shù)據(jù)類型的列。
這對于處理大數(shù)據(jù)表和需要更復雜查詢的情況非常有用。
要啟用 innodb_large_prefix,你可以在 MySQL 配置文件(如 my.cnf 或 my.ini)中添加以下行,并重啟 MySQL 服務以應用更改:
[mysqld] innodb_large_prefix = ON
或者,你可以在運行時通過設(shè)置全局變量來開啟它:
SET GLOBAL innodb_large_prefix = ON;
請注意,為了使 innodb_large_prefix 生效,還需要同時滿足以下條件:
- 數(shù)據(jù)庫文件格式必須是 Barracuda。
- 表格式必須是 DYNAMIC 或 COMPRESSED。
- 對于 ROW_FORMAT=COMPACT 的表,仍然有 767 字節(jié)的索引前綴限制。
有關(guān)這些條件的詳細信息,請參閱 MySQL 文檔。
問題處理
set global innodb_large_prefix=on; show variables like 'innodb_large_prefix'; alter table b Row_format=dynamic; set global innodb_file_format=BARRACUDA;
再次加索引:
[root@localhost:(test) 13:54:18]> CREATE INDEX b_name_IDX USING BTREE ON test.b(name); Query OK, 0 rows affected (0.06 sec) Records: 0 Duplicates: 0 Warnings: 0
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
一次非法關(guān)機導致mysql數(shù)據(jù)表損壞的實例解決
本文介紹由于非法硬件關(guān)機,造成了mysql的數(shù)據(jù)表損壞,數(shù)據(jù)庫不能正常運行的一個實例,接下來是作者排查錯誤的過程,希望對大家能有所幫助2013-01-01
node 多種方法連接mysql數(shù)據(jù)庫(最新推薦)
mysql是一個流行的第三方模塊,可以通過npm安裝,在Node.js 中,有多種方法可以連接 MySQL 數(shù)據(jù)庫,本文通過實例代碼講解node 多種方法連接mysql數(shù)據(jù)庫的示例代碼,感興趣的朋友跟隨小編一起看看吧2023-07-07
mysql 8.0.18各版本安裝及安裝中出現(xiàn)的問題(精華總結(jié))
這篇文章主要介紹了mysql 8.0.18各版本安裝及安裝中出現(xiàn)的問題,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-12-12
percona-toolkit之pt-kill 殺掉mysql查詢或連接的方法
本文主要描述了percona-toolkit中pt-kill的 使用實例 ,及 一些重要參數(shù)的介紹,需要的朋友可以參考下2016-04-04
MySQL數(shù)據(jù)庫的索引原理與慢SQL優(yōu)化的5大原則
這篇文章主要介紹了MySQL數(shù)據(jù)庫的索引原理與慢SQL優(yōu)化的5大原則,包括:建立索引的原則,慢查詢優(yōu)化基本步驟,慢查詢優(yōu)化案例,explain使用,需要的朋友可以參考下2023-02-02
mysql優(yōu)化小技巧之去除重復項實現(xiàn)方法分析【百萬級數(shù)據(jù)】
這篇文章主要介紹了mysql優(yōu)化小技巧之去除重復項實現(xiàn)方法,結(jié)合實例形式分析了mysql去除重復項的方法,并附帶了隨機查詢優(yōu)化的相關(guān)操作技巧,需要的朋友可以參考下2020-01-01
MySQL Threads_running飆升與慢查詢的相關(guān)問題解決
這篇文章主要介紹了MySQL Threads_running飆升與慢查詢的問題解決,幫助大家更好的理解和學習使用MySQL數(shù)據(jù)庫,感興趣的朋友可以了解下2021-05-05

