MySQL索引类型
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL索引类型相关的知识,希望对你有一定的参考价值。
参考技术AMySQL目前主要的索引类型有下面几种:
与前面的普通索引类似,但是他的索引列的值必须是唯一的,所以叫唯一索引,但是这个索引字段如果是空值是可以的,具体创建方式如下:
主键索引是一种特殊的索引,一个表只能有一个主键,不允许有空值,一般是创建表的时候创建主键索引,而且一般习惯设置成自增的,因为对弈MySQL的底层B+树存储起来很方便
组合索引指多个字段上创建的索引,只有在查询时候,查询条件中使用了创建索引时的第一个字段,索引才会生效,他使用遵循最左前缀原则.
索引生效情况:
select * from table where name=1;
select * from table where name=1 and city=2;
select * from table where name=1 and city=2 and age=3;
索引不生效情况:
select * from table where name=1 and age=3;
select * from table where city=2 and age=3;
select * from table where age=3;
select * from table where city=2;
这个遵循的是最左原则,具体MySQL底层对联合索引的存储以及为什么是最左原则,参考本人另外一篇文章最后一段就能看明白
https://www.jianshu.com/p/99aabf9611a3
全文索引主要是用来查找文本中的关键字,而不是直接与索引中的值相比较.fulltext索引跟其他索引大不相同,他更像是一个搜索引擎,而不是简单的where 语句的参数匹配,fulltext索引配合match(匹配)和against(反对)操作使用,而不是一般的where语句加上like,他可以在create table,alter table,create index使用
以上是关于MySQL索引类型的主要内容,如果未能解决你的问题,请参考以下文章