概述
我们知道MySQL Innodb 对于索引长度的限制为 767 字节,并且UTF8mb4字符集是4字节字符集,则 767字节 / 4字节每字符 = 191字符(默认索引最大长度),所以在varchar(255)或char(255) 类型字段上创建索引会失败,提示最大索引长度为767字节。
那么怎么去计算mysql数据库索引长度呢?

实验测试
先看网上一道题目,针对表t,包含了三个字段a、b、c,假设其默认值都非空,现创建组合索引index(a,b,c) 分析select * from t where a=1 and c=1 和select * from t where a=1 and b=1区别?
1、创建表
create table t(a int(5) not null,b int(5) not null,c int(2) not null);
create index idx_all on t(a,b,c);

2、分别执行这两条语句
mysql> explain select * from t where a=1 a

本文介绍了MySQL中索引长度的计算方法,通过实验测试解释了如何根据字段类型和字符集计算key_len,并讨论了索引字段顺序对查询优化的影响。在案例中展示了不同查询条件下key_len的差异,并建议在编写SQL时考虑查询效率。
最低0.47元/天 解锁文章

457

被折叠的 条评论
为什么被折叠?



