[MySQL] mysql索引的长度计算和联合索引

[MySQL] mysql索引的长度计算和联合索引,第1张

概述1.所有的索引字段,如果没有设置not null,则需要加一个字节。2.定长字段,int占4个字节、date占3个字节、char(n)占n个字符。3.变长字段,varchar(n),则有n个字符+两个

1.所有的索引字段,如果没有设置not null,则需要加一个字节。
2.定长字段,int占4个字节、date占3个字节、char(n)占n个字符。
3.变长字段,varchar(n),则有n个字符+两个字节。
4.不同的字符集,一个字符占用的字节数不同。latin1编码的,一个字符占用1个字节,gbk编码的,一个字符占用2个字节,utf8编码的,一个字符占用3个字节。 utf8mb4是一个字符占4个字节
5.使用explain语句查询到的key_len字段,可以适用于上面的计算规则,可以看到查询是否使用到了联合索引
6.MysqL优化器会对条件中的 and的前后顺序根据多列索引顺序自动纠正过来

通过索引的长度查看下面SQL语句是否使用到了索引
CREATE table `index_test` (
`ID` int(10) unsigned NOT NulL auto_INCREMENT,
`name` varchar(100) NOT NulL DEFAulT '',
`gID` int(11) NOT NulL DEFAulT '0',
`age` int(11) NOT NulL DEFAulT '0',
`score` int(10) unsigned NOT NulL DEFAulT '0',
PRIMARY KEY (`ID`),
KEY `name_gID_age_index` (`name`,`gID`,`age`),
KEY `score_index` (`score`)
) ENGINE=InnoDB auto_INCREMENT=7 DEFAulT CHARSET=utf8
insert into index_test values(null,'taoshihan',2,1,0);
insert into index_test values(null,3,0);

explain select * from index_test where name='taoshihan' group by gID;
+----+-------------+------------+------------+-------+--------------------+--------------------+---------+------+------+----------+-------------+
| ID | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |
+----+-------------+------------+------------+-------+--------------------+--------------------+---------+------+------+----------+-------------+
| 1 | SIMPLE | index_test | NulL | index | name_gID_age_index | name_gID_age_index | 310 | NulL | 6 | 66.67 | Using where |
+----+-------------+------------+------------+-------+--------------------+--------------------+---------+------+------+----------+-------------+

key_len的长度是310,也就是100*3+2 + 4 +4

总结

以上是内存溢出为你收集整理的[MySQL] mysql索引的长度计算和联合索引全部内容,希望文章能够帮你解决[MySQL] mysql索引的长度计算和联合索引所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1152683.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存