
需求
在日常需求中,用户使用手机号或者邮箱登录某一个系统,是一个很常见的操作,那如何在类似手机号或者邮箱这样的字段上建立一个合理的索引呢?
前缀索引
前缀索引,就是以一个字段值的一部分作为索引。如果在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框架排名
小程序定制开发是一项多阶段、多技术栈的系统工程,往往需要不同专业角色的紧密协作才能完成高质量的交付。以下是开发过程中常见的核心岗位及其主要职责
微信小程序经历过五年多的发展,开发技术已经很成熟了,越来越多商家想通过小程序转型线上经营来获取更多用户,转化更多的用户。
需预留5-10天进行兼容性、支付接口、功能逻辑的反复测试,避免上线后出现退款异常等问题。总结给出缩短周期的三步法:写清需求文档、分阶段开发先做核心功能、上线后快速收集反馈并预留优化时间,帮助商家与开发团队更精准地规划项目进度。
根据功能与性能要求选取前端(如WXML/WXSS/JavaScript、AXML/ACSS/JavaScript)与后端技术栈(Node.js、Java、Python等),搭建可扩展、安全、高性能的前后端架构;
跨平台小程序框架(如 Taro、Uni-app)——可实现一套代码多端运行(微信、支付宝、H5等),提升代码复用率、降低开发成本,但可能存在性能损耗与平台兼容性问题。
SSL证书是保障网站数据传输安全的基础,也是提升用户信任与SEO排名的必要条件。本文从原理到实操,详解SSL证书的获取、安装与验证全流程,并结合小二CMS的配置技巧,帮助企业快速完成HTTPS部署,让网站既安全又符合搜索引擎规范。
很多企业把内容运营和社会化媒体营销混为一谈,导致策略分散、资源浪费。本文深度解析两者的核心差异、目标导向与执行方式,并结合小二CMS在多平台内容管理与分发上的优势,教你如何让二者相辅相成,构建从内容生产到社交裂变的完整营销闭环,提升品牌影响力与转化效率。
很多企业在建站后发现“不知道写什么”,内容断更导致排名下滑、用户流失。本文针对“企业网站没有内容可写”的常见困境,结合小二CMS的智能选题、素材管理与协作功能,提供从内部挖潜到外部延展的实用方法,帮你建立可持续的内容生产体系,让网站始终有料可发、有吸引力。