mysql 索引长度计算_面试官:如何精确计算mysql数据库索引长度?

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

概述

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

那么怎么去计算mysql数据库索引长度呢?

cc66f74f8f149af88dd7a6b505bb8be4.png

实验测试

先看网上一道题目,针对表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);

bcc343b824d18c89f7d2a7cf00fce80f.png

2、分别执行这两条语句

mysql> explain select * from t where a=1 a

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值