MySQL怎么给字符串加一个高效索引

2023-05-28 21:10:51 209
摘要:在日常需求中,用户使用手机号或者邮箱登录某一个系统,是一个很常见的操作,那如何在类似手机号或者邮箱这样的字段上建立一个合理的索引呢?

需求
在日常需求中,用户使用手机号或者邮箱登录某一个系统,是一个很常见的操作,那如何在类似手机号或者邮箱这样的字段上建立一个合理的索引呢?

前缀索引
前缀索引,就是以一个字段值的一部分作为索引。如果在MySQL中创建索引时不指定索引字段的长度,则会使用整个字符串来建立索引。



语句1:

alter table test add index idx(email);

语句2:

alter table test add index idx(email(8));

对于语句1,创建的索引中,会包含每条记录中的整个email字符串值。

对于语句2,创建的索引中,保存的是每条记录中email字段的前8个字节。

使用前缀索引的优势很明显,那就是索引占用的空间会更小,整个索引树会更紧凑,树的高度相对更低。

但是相应的,索引的区分度会变低,可能导致索引扫描行数增加。

在我们创建索引时,索引的区分度是一个很重要的指标。区分度越高,重复的值就越少,扫描的效率就越高。

合理规划前缀索引的使用长度可以不仅节省空间,同时也避免需要额外扫描行数。具体使用多少的长度,建议根据我们的实际业务场景来判断、测试。

倒序+前缀索引
倒序+前缀索引有一个经典的使用场景,就是对身份证号做索引。

假设我们现在要维护一个市县所有人的身份信息,其中按身份证号查询是一个高频场景。

身份证号码一共15位或者18位,一般来说,同一个市县的人身份证号前6位一般是相同的,如果直接对身份证号做全索引,那么会比较浪费空间,导致性能下降。如果使用直接前缀索引,前6位的区分度非常低(甚至可以说没有),因为大多数值的前6位都相同。

这时,使用倒序+前缀索引的好处就体现出来了。

我们先将身份证倒序存储,或者冗余一个倒序的身份证号字段,然后取前6位做前缀索引。

身份证后6位的区分度已经基本上够我们使用了,如果你还觉得查询速度不够,那取前8位也是没问题的。

你觉得这篇文章怎么样?

63 0
扫描二维码与小二CMS创始人沟通

7*24小时为您服务

小二CMS专注于高端网站定制、系统开发、商城开发、外贸网站建设、公众号开发、小程序开发、网站优化推广、安全运维等技术领域。是高端定制网站领域著名服务商!

本文标题:MySQL怎么给字符串加一个高效索引
免责声明:文章《MySQL怎么给字符串加一个高效索引》来至网络,文章表达观点不代表本站观点,文章版权属于原作者所有,若有侵权,请联系本站站长处理!
不忘初心,方得始终
中高端网站定制开发服务商
与我们取得联系
198-1095-0281 460623785

好作品自己会说话,

我们敬畏您给予的点滴信任 !

期待携手合作,请立即咨询我们:
QQ咨询
微信咨询
198-1095-0281
我们用心,期待您成为我们的客户
联系QQ客服

QQ扫码联系客服

联系微信客服

微信扫码联系客服

微信号: 198-1095-0281
添加微信好友, 详细咨询相关信息。

复制并跳转微信
19810950281