mysql前缀索引_MySQL

php中文网
发布: 2016-06-01 13:36:16
原创
1151人浏览过

bitsCN.com

mysql前缀索引

 

应用场景:

数据库里有个地址(address)字段,类型为varchar(100),业务决定了要经常根据
address来进行查询。    

确定选择性:

Sql代码  

SELECT count(DISTINCT(address))/count(*) AS Selectivity FROM info;    

+-------------+     

| Selectivity |    

Yes!SUN企业网站系统 3.5 Build 20100303
Yes!SUN企业网站系统 3.5 Build 20100303

Yes!Sun基于PHP+MYSQL技术,体积小巧、应用灵活、功能强大,是一款为企业网站量身打造的WEB系统。其创新的设计理念,为企业网的开发设计及使用带来了全新的体验:支持前沿技术:动态缓存、伪静态、静态生成、友好URL、SEO设置等提升网站性能、用户体验、搜索引擎友好度的技术均为Yes!Sun所支持。易于二次开发:采用独创的平台化理念,按需定制项目中的各种元素,如:产品属性、产品相册、新闻列表

Yes!SUN企业网站系统 3.5 Build 20100303 0
查看详情 Yes!SUN企业网站系统 3.5 Build 20100303

+-------------+     

|      0.8745 |    

+-------------+    

 

选择性很好,但是长度为100,对整个字段建立索引显然不合适,可以考虑建立
前缀索引,例如,看看其选择性:    

Sql代码  

SELECT count(DISTINCT(left(address,5)))/count(*) AS Selectivity FROM info;    

+-------------+     

| Selectivity |    

+-------------+     

|      0.5981 |    

+-------------+     

 

选择性还不错,但和0.8745相比还是太低,所以我们可以将前缀长度增加到10,再看看
选择性:    

Sql代码  

SELECT count(DISTINCT(left(address,10)))/count(*) AS Selectivity FROM info;    

+-------------+     

| Selectivity |    

+-------------+     

|      0.8239 |    

+-------------+    

 

和0.8745已经很接近了,但是索引长度只有10,所以就可以决定建立前缀索引了。

前缀索引兼顾索引大小和查询速度,但是其缺点是不能用于ORDER BY和GROUP BY
操作,也不能用于Covering index(即当索引本身包含查询所需全部数据时,不再访问
数据文件本身)。

 

bitsCN.com
相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号