mysql 索引作用范围

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql 索引作用范围相关的知识,希望对你有一定的参考价值。

索引是什么? 
模式(schema)中的一个数据库对象。 
在数据库中用来加速对表的查询。 
通过使用快速访问方法确定定位数据,减少磁盘的I/O 
与表独立存放,但不能独立存在,必须属于某个表 
由数据库自动维护,表被删除时,该表上的索引自动被删除 
索引的作用类似于书的目录,几乎没有一本书没有目录,因此几乎没有一张表没有索引。

自动:当在表上定义一个PRIMARY KEY 或者 UNIQUE 约束时,数据库自动创建一个对应的索引。 
手动:用户可以创建索引以加速查询。

创建一个索引: 
手动创建一个索引:

CREATE INDEX index_tb_student_name ON tbl_student(stu_name)

上面索引的名字可以自己命名

使用索引(在where 之后加上索引,提高传效率)

select * from tbl_student where stu_name=?

总之: 
索引在经常查询的字段上面建立索引。 
利用index对查询进行优化(index可以避免对表的一个全面扫描)

原理: 
当以某个字段建立一个索引的时候,数据库就会生成一个索引页,当我们查询数据时,Oracle会先查索引页,这样就能够很快的查找到要找的记录。

注意: 
如果表的列很少,不适合建索引。 
当执行过多次的insert,delete,update后,会出现索引碎片,影响查询速度,我们应该对索引进行重组,其方法如下: 
drop index index_name; 
create index index_name on table(column) 
其实,就是删除掉索引,重新再建立索引。

拓展: 
对于创建的多列索引,只要查询条件使用了最左边的列,索引一般就会使用。

对于使用like的查询,查询如果是 “%aaa” 不会使用到索引,‘aaa%’会使用到索引。

下列的表将不会使用索引: 
1、如果条件中有or,即使其中有条件带索引也不会使用。 
2、对于多列索引,不是使用的第一部分,则不会使用索引。 
3、like查询是以%开头 
4、如果列类型是字符串,那一定要再条件中将数据使用引号引起来,否则不使用索引。(添加是,字符串必须“) 
5、如果MySQL估计使用全表扫描比使用索引快,则不使用索引。

alter table account add index my_index(login,name) 

//login就是最左边的列,name就是右边的列

如果表中有复合索引,索引作用在多列上,此时我们注意:对于创建的多列索引,只要查询条件使用了最左边的列,索引一般会被使用。

此时:

select * from account where name="timchen"

由于使用的是右侧的列,此时索引是不会生效的,如何知道呢? 
添加explain 此时possible_key的值是为空的。

但是当我们使用左侧的列是,explain的值不为空。

 

转载 

timchen525的专栏
























以上是关于mysql 索引作用范围的主要内容,如果未能解决你的问题,请参考以下文章

Mysql :索引

MySQL索引的用处

Mysql索引及执行计划

Mysql索引及执行计划

hashmap面试题,mysql分页查询sql语句

MySQL 千万 级数据量根据(索引)优化 查询 速度