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

mysql5.6建立索引報錯1709問題及解決

 更新時間:2024年03月29日 09:30:36   作者:ReadVersion  
這篇文章主要介紹了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)文章

最新評論