需求
在日常需求中,用户使用手机号或者邮箱登录某一个系统,是一个很常见的操作,那如何在类似手机号或者邮箱这样的字段上建立一个合理的索引呢?
前缀索引
前缀索引,就是以一个字段值的一部分作为索引。如果在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位也是没问题的。
扫描二维码与小二CMS创始人沟通:
小二CMS专注于高端网站定制、系统开发、商城开发、外贸网站建设、公众号开发、小程序开发、网站优化推广、安全运维等技术领域。是高端定制网站领域著名服务商!
上一篇: 修改DNS解决个别网站无法访问的问题
下一篇: 2023年最流行的10款前端UI框架排名
在智能家居从概念走向现实的今天,消费者对"全屋智能"的期待已从科幻电影中的场景,转化为对便捷、舒适、个性化居住体验的切实需求。
在微信生态中构建网站已成为企业品牌展示、用户运营与商业转化的核心场景。区别于传统网站,微信网站需深度适配微信的交互逻辑与功能接口,实现从流量获取到用户沉淀的闭环。
在移动互联网迅猛发展的当下,微信作为一款拥有庞大用户群体的超级应用,不仅改变了人们的社交方式,也深刻影响了商业运营模式。
在数字化浪潮席卷的今天,一个专业、高效且符合企业特色的网站已成为企业展示形象、拓展业务、提升竞争力的关键窗口。
在人工智能(AI)技术以迅猛之势席卷各个领域的当下,一个疑问悄然浮现:网站是否会被AI工具替代?
在用户注意力碎片化、搜索引擎排名与加载速度强关联的今天,网站访问速度已成为影响用户体验、转化率及SEO效果的核心指标。
在搜索引擎流量成本持续攀升的背景下,企业SEO投入与产出比成为核心关注点。SEO关键词排名收费模式已从传统的“按词计费”向“效果导向+技术赋能”转型
在数字化竞争白热化的今天,企业网站已从“信息展示窗口”升级为“品牌价值载体”与“用户转化引擎”。