赞
踩
1.版本
1)操作系统
cat /etc/issue
cat /etc/issue
CentOS release 6.6 (Final)
Kernel \r on an \m
cat /proc/version
cat /proc/version
Linux version 2.6.32-504.el6.x86_64 (mockbuild@c6b9.bsys.dev.centos.org) (gcc version 4.4.7 20120313 (Red Hat 4.4.7-11) (GCC) ) #1 SMP Wed Oct 15 04:27:16 UTC 2014
2)mysql数据库版本
mysql --version
mysql Ver 14.14 Distrib 5.6.26, for linux-glibc2.5 (x86_64) using EditLine wrapper
2.问题描述
2.1 发现问题
今天在修改innodb表的某个列的长度时,报如下错误:
3.1 问题原因分析
其实从上面的报错中我们已经能看是因为索引达到长度限制,所以报错。查看id列是否有索引:
3.2 关于mysql索引长度限制
1)单列索引长度限制
从上面可以看出,mysql 在创建单列索引的时候对列的长度是有限制的 myisam和innodb存储引擎下长度限制分别为1000 bytes和767 bytes。(注意bytes和character的区别)
2) 组合索引长度限制对于innodb存储引擎,多列索引的长度限制如下:
每个列的长度不能大于767 bytes;所有组成索引列的长度和不能大于3072 bytes
参考如下例子(下面默认使用的使用innodb存储引擎,smallint 占2个bytes,timestamp占4个bytes,utf8字符集。utf8字符集下,一个character占三个byte)
对于myisam存储引擎,多列索引长度限制如下:
每个列的长度不能大于1000 bytes,所有组成索引列的长度和不能大于1000 bytes
例子如下
4. 问题解决方案
1) using col_name(length) syntax to specify an index prefix length.
对列的前面某部分创建索引
2) 启用innodb_large_prefix参数
例子如下:
参考阅读:
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。