mysql 索引前缀

需求:

  • 在创建索引的时候报错了 Specified key 'uniq_code' was too long; max key length is 767 bytes.

进程:

  • 查阅文档信息之后发现,索引创建是有长度限制的
  • 要解决这个问题有两个方案
    1 . 修正当前所需要创建索引的字段的长度比如原先是 varchar(200) 修正为 varchar(20), 但是这个行为可能会导致数据变更,这个需要先确认表中数据都是20以内的长度
    2 . 使用前缀索引,前缀索引就是取数据库里某一列的数据的前n 个字符来当索引,这个方案的关键在于怎么判定前缀的长度
  • 前缀的唯一比例最好和全列的唯一比例相近,越接近越好,查询语句如下
sql 复制代码
#获取全列的比例
SELECT COUNT(DISTINCT column) / COUNT(*) FROM table;
#获取前缀的比例
SELECT COUNT(DISTINCT LEFT(column, 19)) / COUNT(*) FROM table;
  • 但这个也会有个弊端,因为数据量是一直在增加的,到后面的时候可能这个前缀长度可能就不够了,所以会有需要再次维护的情况,所以最好还是在最开始的时候就限定好字段的长度,但是使用前缀可以更省空间,这也是一个优势
相关推荐
闲人编程9 分钟前
商品管理与库存系统
服务器·网络·数据库·python·api·数据模型·codecapsule
h***381815 分钟前
maven导入spring框架
数据库·spring·maven
樱花味的小奶牛24 分钟前
DECLARE CURSOR 才允许使用 FOR UPDATE 子句
数据库·sql
雁凡彡26 分钟前
mybatis-plus中sqlserver 查询数组中指定位置前的数据
数据库·sqlserver·mybatis
问今域中43 分钟前
Spring Security登录认证
数据库·sql·oracle
qq_124987075344 分钟前
基于springboot的仁和机构的体检预约系统的设计与实现(源码+论文+部署+安装)
java·spring boot·后端·mysql·spring·毕业设计·计算机毕业设计
jgyzl1 小时前
2026.1.7 tlias三层架构
java·mysql·架构
JOEH602 小时前
🚀 数据库插入 1000 万数据?别再傻傻用 for 循环了!实测 5 种方式效率对比
数据库·后端
lllsure2 小时前
【MySQL】数据分片
数据库·mysql
语落心生2 小时前
深入doris查询计划以及io调度(五)列式存储结构 - 分析Segment格式、列数据编码
数据库