mysql组合索引顺序参考
问题背景 :
当我们需要创建一个组合索引, 索引的顺序对于效率影响很大, 怎么确定索引的顺序;
解决方法 :
我们应该依据字段的全局基数和选择性, 而不是字段的某个具体的值来确定;
表结构 :
dc_listing

代码 :
SELECT
	  COUNT(DISTINCT accountId) / COUNT(*) AS accountId_sel,
	  COUNT(DISTINCT userName) / COUNT(*) AS userName_sel,
	  COUNT(*)
FROM
	  dc_listing

结果:

可以看到accountId的选择性更高, 所以我们应该讲accountId这个字段放在组合索引前面

存在问题 :
对于一些特殊的值, 比如超级用户, 如果他满足大部分的查询条件, 即这个基数对这个值可以说是无效的参考.
避免这种问题, 只能从代码层面屏蔽, 区分这类数据合组, 禁止针对这类值进行这个查询;
参考 msyql高性能 5.3.4 章节, 有更详细例子
mysql组合索引顺序参考的更多相关文章
- mysql 组合索引
		
MySQL单列索引是我们使用MySQL数据库中经常会见到的,MySQL单列索引和组合索引的区别可能有很多人还不是十分的了解,下面就为您分析两者的主要区别,供您参考学习. 为了形象地对比两者,再建一个表 ...
 - 【转】MYSQL数据库四种索引类型的简单使用--MYSQL组合索引“最左前缀”原则
		
MYSQL数据库索引类型包括普通索引,唯一索引,主键索引与组合索引,这里对这些索引的做一些简单描述: (1)普通索引 这是最基本的MySQL数据库索引,它没有任何限制.它有以下几种创建方式: 创建索引 ...
 - mysql组合索引之最左原则
		
为什么在单列索引的基础上还需要组合索引? select product_id from orders where order_id in (123, 312, 223, 132, 224); 我们当然 ...
 - mysql组合索引与字段顺序
		
很多时候,我们在mysql中创建了索引,但是某些查询还是很慢,根本就没有使用到索引!一般来说,可能是某些字段没有创建索引,或者是组合索引中字段的顺序与查询语句中字段的顺序不符. 看下面的例子:假设有一 ...
 - [转]mysql组合索引与字段顺序
		
下列转自:http://www.tech-q.cn/archiver/tid-11673.html 很多时候,我们在mysql中创建了索引,但是某些查询还是很慢,根本就没有使用到索引!一般来说,可能是 ...
 - mysql组合索引的有序性<转>
		
昨天同事关于军规里的一条mysql索引的问题咨询我,才发现自己也不太了解组合索引的规则.于是来记录一下: [推荐]如果有order by的场景,请注意利用索引的有序性.order by 最后的字段是组 ...
 - MySQL组合索引最左匹配原则
		
几个重要的概念 1.对于mysql来说,一条sql中,一个表无论其蕴含的索引有多少,但是有且只用一条. 2.对于多列索引来说(a,b,c)其相当于3个索引(a),(a,b),(a,b,c)3个索引,又 ...
 - MySQL单列索引和组合索引的区别介绍
		
MySQL单列索引和组合索引的区别介绍 作者:佚名出处:IT专家网2010-11-22 13:05 MySQL单列索引是我们使用MySQL数据库中经常会见到的,MySQL单列索引和组合索引的区别可能有 ...
 - [转]MySQL单列索引和组合索引的区别介绍
		
FROM : http://database.ctocio.com.cn/353/11664853.shtml MySQL单列索引是我们使用MySQL数据库中经常会见到的,MySQL单列索引和组合索引 ...
 
随机推荐
- css3 -- 浏览器支持
			
浏览器支持的前缀: 1.浏览器兼容前缀 -webkit-transform:rotate(-3deg); /*为Chrome/Safari*/ -moz-transform:rotate(-3deg) ...
 - Maven的简单使用,HelloWorld
			
安装好Maven后就用一个简单的HelloWorld程序来测试一下,体验一下Maven.至于不懂的地方,请查看<Maven实战>书籍. 书籍网址:http://download.csdn. ...
 - Docker搭建便捷的开发者环境
			
你可能遇到这样的场景:开发软件时,需要像数据库(mysql,mongodb).消息系统(rabbitmq).缓存服务(redis)等其它依赖服务.当然我们可以找台机器,一步步安装依赖,然后把所有依赖的 ...
 - Fetch from Upstream 变灰失效
			
Team——>Remote——>Configure Fetch from Upstream… Team——>Remote——>Configure Push to Upstre ...
 - 【转】SpringTest框架JUnit单元测试用例获取ApplicationContext实例的方法
			
转自:http://www.coderli.com/junit-spring-test-applicationcontext JUnit单元测试用例中使用Spring框架,直接方式如下. @RunWi ...
 - BZOJ4454: C Language Practice
			
Description Input 第一行输入一个正整数T(T<=85),表示测试数据的组数. 每组数据第一行包含两个正整数n,m(1<=n,m<=2000),表示序列的长度. 第二 ...
 - 你也可以用java的swing可以做出这么炫的mp3播放器_源码下载
			
I had published the blog : 你用java的swing可以做出这么炫的mp3播放器吗? and to display some screenshots about this M ...
 - spring源码学习之路---IOC实现原理(三)
			
作者:zuoxiaolong8810(左潇龙),转载请注明出处,特别说明:本博文来自博主原博客,为保证新博客中博文的完整性,特复制到此留存,如需转载请注明新博客地址即可. 上一章我们已经初步认识了Be ...
 - ELK_日志分析系统Logstash+ElasticSearch+Kibana4
			
elk 日志分析系统 Logstash+ElasticSearch+Kibana4 logstash 管理日志和事件的工具 ElasticSearch 搜索 Kibana4 功能强大的数据显示客户端 ...
 - 使用plsql创建用户并授权(图形化界面)
			
使用sys用户登录数据库(或者有dba权限的[还不知道具体的区别,但是能用]) 在左边的对象列表中找到USERS,右键点击USERS,选择“新建用户”选项 其他安装下面的图片步骤来即可: OK!