mysql #1709 - Index column size too large. The maximum column size is 767 bytes.

https://blog.csdn.net/qq_35209838/article/details/90238991

 

#1709 - Index column size too large. The maximum column size is 767 bytes.是什么原因导致的,如何处理?
一、原因
1、对于行格式为REDUNDANT和COMPACT的InnoDB表来说,索引的最大长度为767字节
2、行格式为DYNAMIC和COMPRESSED格式的InnoDB表最大索引长度允许达到3072字节(注:8.0版本之前,要求innodb_file_format=Barracuda,且innodb_large_prefix=1。 且8.0以后该参数已废弃)
3、注意,即便设置innodb_large_prefix=1,但若行格式是REDUNDANT和COMPACT时调整无效,且5.7.6版本以前该参数默认是关闭的,5.7.7版本后默认开启。8.0后该参数也已废弃
4、索引长度计算规则:
  4.1 一般地,key_len等于索引列类型字节长度,例如tinyint类型为1字节,int类型为4字节,bigint为8字节
  4.2 如果是字符串类型,还需要同时考虑字符集因素(latin1为1字节/gbk为2字节/utf8为3字节/utf8mb4为4字节),例如:CHAR(30) UTF8则key_len至少是90字节
  4.3 如果是日期时间型还需要考虑精度值(5.6.4版本以后),如datetime为5字节+精度值,timestamp为4字节+精度值
  4.4 若该列类型定义时允许NULL,还需要再加1字节
  4.5 若该列类型为变长类型,例如 VARCHAR(TEXT\BLOB不允许整列创建索引,如果创建部分索引也被视为动态列类型),还需要再加2字节

二、处理方法
1、降低索引长度,采用部分索引而不是整列索引,如:create index idx_xx on t(code(30))
2、修改innodb_file_format为Barracuda,同时修改表的row format为DYNAMIC,使得最大索引长度增加到3072字节,如:alter table t row_format=dynamic
————————————————
版权声明:本文为CSDN博主「DBA之路」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_35209838/article/details/90238991

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Index column size too large. The maximum column size is 767 bytes. 这个错误通常在MySQL数据库上建立索引时出现。具体原因是因为MySQL Innodb引擎表索引字段长度的限制是767字节。所以当对于多字节字符集的大字段(或者多字段组合索引)创建索引时,会出现这个错误。 解决这个问题的方法有几种。一种方法是减少索引字段的长度,比如将字段长度缩短到767字节以下。另一种方法是使用前缀索引,通过只索引字段的前几个字符来解决。还有一种方法是更改数据库的字符集,将字符集改为utf8或者latin等较小的字符集。 如果你使用的是MySQL 5.7.7或更高版本,还可以通过修改配置文件来解决这个问题。在配置文件中添加以下内容: ``` <span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [提要:自托管的RSS阅读器-带有Symfony的API-独立的html客户端-Google阅读器替代](https://download.csdn.net/download/weixin_42127748/15095482)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [解决MySQLindex column size too large. the maximum column size is 767 bytes 问题](https://blog.csdn.net/weixin_52005792/article/details/118157681)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [Index column size too large. The maximum column size is 767 bytes.](https://blog.csdn.net/m0_71124383/article/details/129809980)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值