本文实例讲述了mysql建立高效的索引。分享给大家供大家参考,具体如下:
如何建立理想的索引?
- 查询频繁度
- 区分度
- 索引长度
- 覆盖字段
区分度
假设100万用户,性别基本上男/女各为50W, 区分度就低。
长度小
索引长度直接影响索引文件的大小,影响增删改的速度,并间接影响查询速度(占用内存多).
区分度高,长度小
问题:如果让区分度高,而长度小?
答:可以针对列中的值,从左往右截取部分,来建索引
(1)截的越短, 重复度越高,区分度越小, 索引效果越不好
(2)截的越长, 重复度越低,区分度越高, 索引效果越好,但带来的影响也越大–增删改变慢,并间影响查询速度.
所以, 我们要在 区分度 + 长度 两者上,取得一个平衡。惯用手法:截取不同长度,并测试其区分度。
假设我们有一张表:英语4级的单词表,里面有13324条记录,我们怎么给name字段加索引呢?
如果计算区分度?
截取单词第1位的不重复数:
select count(distinct left(name,1)) from dict
总的数量:
select count(*) from dict
区分度:不重复数/总的数量,sql语句如下:
select (select count(distinct left(name,1)) from dict) / (select count(*) from dict) as rate;
然后按照这样的步骤把其他长度所对应的区分度给找出来,看一个这个图表,可以知道当长度为11的时候重复度仅仅为1%,我们可以考虑建立11位长的索引
alter table dict add index name name(11);
左前缀不好区分的情况
对于左前缀不易区分的列 ,建立索引的技巧
如url列
http://www.baidu.com
http://www.web-bc.cn
列的前11个字符都是一样的,不易区分, 可以用如下2个办法来解决
(1)把列内容倒过来存储,并建立索引
moc.udiab.www//:ptth
nc.cb-bew.www//://ptth
这样左前缀区分度大
(2)伪hash索引效果
同时存url和url_hash列
#建表 create table t10 ( id int primary key, url char(60) not null default '' ); #插入数据 insert into t10 values (1,'http://www.baidu.com'), (2,'http://www.sina.com'), (3,'http://www.sohu.com.cn'), (4,'http://www.onlinedown.net'), (5,'http://www.gov.cn'); #修改表结构,添加urlcrc列 alter table t10 add urlcrc int unsigned not null;
在存储的时候,将url对应的crc32码一同插入到数据库中,然后按照urlcrc字段建立索引,然后查找的时候,我们在业务层中将对应的url转换为crc32进行查找,就可以利用上索引了。
因为crc的结果是32位int无符号数,因此当数据超过40亿,也会有重复,但这是值得的.(索引长度为int4个字节)
多列索引
多列索引的考虑因素—列的查询频率 , 列的区分度, 注意一定要结合实际业务场景
以ecshop商城为例, goods表中的cat_id,brand_id,做多列索引,从区分度看,brand_id区分度更高, 但从 商城的实际业务业务看, 顾客一般先选大分类->小分类->品牌,最终选择建立2个索引:
(1)index(cat_id,brand_id)
(2)index(cat_id,shop_price)
甚至可以再加 (3)index(cat_id,brand_id,shop_price),3个冗余索引
但(3)中的前2列和(1)中的前2列一样,所以可以再去掉(1),建立2个索引
index(cat_id,price)
和 index(cat_id,brand_id,shop_price);
更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL索引操作技巧汇总》、《MySQL常用函数大汇总》、《MySQL日志操作技巧大全》、《MySQL事务操作技巧汇总》、《MySQL存储过程技巧大全》及《MySQL数据库锁相关技巧汇总》
希望本文所述对大家MySQL数据库计有所帮助。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]