索引长度和区分度

建立索引的原则:

1:查询频繁

2:区分度高  

3:长度小  

4: 尽量能覆盖常用查询字段.


索引长度:
1: 索引越短, 重复度越高,区分度越小, 索引效果越不好
2: 索引越长, 重复度越低,区分度越高, 索引效果越好,但带来的影响也越大--索引文件越大,增删改变慢,并且影响查询速度.

所以, 要在  区分度 + 长度  两者上,取得一个平衡.


使用技巧:如果从左边截取区分度较低,可以考虑从右边截取

惯用手法: 截取不同长度,并测试其区分度

 

[sql]  view plain  copy
 
  1. <span style="font-size:18px;">select count(distinct left(word,6))/count(*) from dict;   
  2. +---------------------------------------+  
  3. count(distinct left(word,6))/count(*) |  
  4. +---------------------------------------+  
  5. |                                0.9992 |  
  6. +---------------------------------------+</span>  

 

截取word字段长度,从1开始截取,计算字符前缀没有重复的字符占全部数据的比例


对于一般的系统应用: 区别度能达到0.1,索引的性能就可以接受.

 

转载于:https://www.cnblogs.com/lpfuture/p/5773083.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值