MySQL ERROR 1709 (HY000)


创建一张表,其中有个varchar 大字段,并且在这个字段上建索引,结果发现MySQL报错:

ERROR 1709 (HY000): Index column size too large. The maximum column size is 767 bytes.


以下为建表语句:

create table piratebay(
SYS_ID		int ,
FILE_NAME	VARCHAR(200),
FILE_ID		VARCHAR(30),
NUM1		VARCHAR(30),
NUM2		VARCHAR(30),
MAGNET_LINK	VARCHAR(500),
PRIMARY KEY	(sys_id),
KEY 		piratebay_n1 (FILE_NAME)) 
engine=innodb;

MySQL 环境配置:

Server version: 5.6.28-log MySQL Community Server (GPL)

Server characterset: utf8mb4
Db       characterset: utf8mb4


解决办法:

(1)查看相关配置并作出如下设置

innodb_large_prefix = ON 
innodb_file_format = Barracuda 
innodb_file_per_table = ON 

(2)修改建表语句,加入 row_format=DYNAMIC

create table piratebay(
SYS_ID		int ,
FILE_NAME	VARCHAR(200),
FILE_ID		VARCHAR(30),
NUM1		VARCHAR(30),
NUM2		VARCHAR(30),
MAGNET_LINK	VARCHAR(500),
PRIMARY KEY	(sys_id),
KEY 		piratebay_n1 (FILE_NAME)) 
engine=innodb row_format=dynamic;


原因:

       MySQL 索引只支持767个字节,utf8mb4 每个字符占用4个字节,所以索引最大长度只能为191个字符,即varchar(191),若想要使用更大的字段,mysql需要设置成支持数据压缩,并且修改表属性 row_format ={DYNAMIC|COMPRESSED}

官方解释:

https://dev.mysql.com/doc/refman/5.5/en/innodb-parameters.html#sysvar_innodb_large_prefix



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值