mysql建索引原则及索引区别

原创 2016年08月30日 15:54:21
索引原则
1、最左前缀匹配
    mysql 会一直向右匹配直到遇到范围查询(<,>,between,like)就停止匹配。
    如:a=1 and b=1 and c>3 and d=4 ,如果建立(a,b,c,d)顺序的索引,d是使用不到索引的,如果建立(a,b,d,c)的索引则都可以用到,a b d 可以任意调整顺序。
2、= 和 in 可以乱序。
    比如:a=1 and b =2 and c=3,   建立(a,b,c)索引可以任意顺序,mysql优化器会自动优化。
3、尽量选择区分高度的列作为索引。
    区分度的公式:count(distinct col)/count(*),表示字段不重复比例,比例越大扫描记录数越少,唯一键的区分度是1,而一些状态、性别字段可能在大数据面前区分度就是0 。
    一般需要join 的字段我们都要求是0.1 以上,即平均1条扫描10条记录
4、索引列不能参与计算

索引使用
1、索引的列是出现在where 子句后面或连接子句中指定的列
2、使用唯一索引,索引的列基数越大越好。(不同的值)
3、使用短索引。如果对字符串列进行索引,应该指定一个长度,只要有可能就应该这样做。例如有一个varchar(200)列,如果在前10或20个字符多数值是唯一的,就不要对整列进行索引。对前10或20个字符进行索引能节省大量的索引空间,使查询更快。较少的索引涉及的磁盘IO较少,较短的值的比较速度更快。主要是:对于较短的键值,索引高速缓存中的块能容纳更多的键值,因此,MySql也可以在内存中容纳更多的值。这样就增加了找到行而不用读取索引中较多块的可能性。
4、最左前缀。创建N列索引时,实际创建了MySql可以利用的N个索引。多列索引可起几个索引的作用,加为可利用索引中最左边的列集来匹配行。这样的列集称为最左前缀。
5、不要过度索引
6、对于InnoDB 存储引擎的表,记录默认会执照一定的顺序保存,如果有明确的定义主键,则按照主键顺序保存。若没有主键,有唯一索引,就按照唯一索引的顺序保存。如果没有主键也没有唯一索引,表中会自动生成一个内部列,按照这个列的顺序保存。按照主键或者内部列进行的访问是最快的。InnoDB 表的普通索引都会保存主键的键值,所以主键要尽量的选择较短的数据类型。

索引区别
BTREE 索引
    >,<,>=,<=,between,!= ,  <> ,  Like 'pattern'('pattern' 不以通配符开始),使用这些操作符时,都可以使用相关列上的索引
HASH 索引
    只用于= 或 <=> 操作符的等式比较
    优化器不能使用HASH 索引来加速ORDER BY 操作
    MySQL 不能确定在两个值之间大约有多少行。如果将一个MyISAM 表改为HASH 索引MEMORY 表,会影响一些查询的执行效率
    只能使用整个关键字来搜索一行

mysql建索引的几大原则

1.选择唯一性索引 唯一性索引的值是唯一的,可以更快速的通过该索引来确定某条记录。例如,学生表中学号是具有唯一性的字段。为该字段建立唯一性索引可以很快的确定某个学生的信息。如果使用姓名的话,可能...

mysql建索引的几大原则

1.选择唯一性索引 唯一性索引的值是唯一的,可以更快速的通过该索引来确定某条记录。例如,学生表中学号是具有唯一性的字段。为该字段建立唯一性索引可以很快的确定某个学生的信息。如果使用姓名的话,可能...

mysql建索引的几大原则

1.选择唯一性索引唯一性索引的值是唯一的,可以更快速的通过该索引来确定某条记录。例如,学生表中学号是具有唯一性的字段。为该字段建立唯一性索引可以很快的确定某个学生的信息。如果使用姓名的话,可能存在同名...
  • wu_0916
  • wu_0916
  • 2017年11月24日 11:49
  • 21

mysql正确建立索引以及最左前缀原则

1. 索引建立的原则 用于索引的最好的备选数据列是那些出现在WHERE子句、join子句、ORDER BY或GROUP BY子句中的列。 仅仅出现在SELECT关键字后面的输出数据列列表中的数据列...

mysql索引的最左前缀原则

联合索引有一个最左前缀原则,所以建立联合索引的时候,这个联合索引的字段顺序非常重要 下面写了例子说明这个:CREATE TABLE `test_myisam` ( `id` int(11) NO...
  • topwqp
  • topwqp
  • 2016年07月30日 09:07
  • 2302

MySql 创建索引原则

为了使索引的使用效率更高,在创建索引时,必须考虑在哪些字段上创建索引和创建什么类型的索引。本小节将向读者介绍一些索引的设计原则。   1.选择唯一性索引   唯一性索引的值是唯一的,可以更快速...

MySql 创建索引原则

为了使索引的使用效率更高,在创建索引时,必须考虑在哪些字段上创建索引和创建什么类型的索引。本小节将向读者介绍一些索引的设计原则。   1.选择唯一性索引   唯一性索引的值是唯一的,可以更快速的通过该...

MySQL 索引基本原则

索引用于快速找出在某个列中有一特定值的行。不使用索引,MySQL必须从第1条记录开始然后读完整个表直到找出相关的行,还需要考虑每次读入数据页的IO开销。而如果采取索引,则可以根据索引指向的页以及记录在...

B+树|MYSQL索引使用原则

MYSQL一直了解得都不多,之前写sql准备提交生产环境之前的时候,老员工帮我检查了下sql,让修改了一下存储引擎,当时我使用的是Myisam,后面改成InnoDB了。为什么要改成这样,之前都没有听过...

Mysql设计索引的原则

设计索引的原则 1. 搜索的索引列,不一定是所要选择的列。换句话说,最适合索引的列是出现在 WHERE 子 句中的列,或连接子句中指定的列,而不是出现在 SELECT 关键字后的选择列表中的 列 ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:mysql建索引原则及索引区别
举报原因:
原因补充:

(最多只允许输入30个字)