索引的使用
主键索引与唯一索引的区别
-
主键是一种约束,唯一索引是一种索引,两者在本质上是不同的。
-
主键创建后一定包含一个唯一性索引,唯一性索引并不一定就是主键。
-
唯一性索引列允许空值,而主键列不允许为空值。
-
主键列在创建时,已经默认为空值 ++ 唯一索引了。
-
一个表最多只能创建一个主键,但可以创建多个唯一索引。
-
主键更适合那些不容易更改的唯一标识,如自动递增列、身份证号等。
-
主键可以被其他表引用为外键,而唯一索引不能。
复合索引
-
用户可以在多个列上建立索引,这种索引叫做复合索引(组合索引)。
-
就是几个字段联合在一起组成一个索引.复合索引的创建方法与创建单一索引的方法完全一样。
-
但复合索引在数据库操作期间所需的开销更小,可以代替多个单一索引。
-
当表的行数远远大于索引键的数目时,使用这种方式可以明显加快表的查询速度。
使用索引的场景
-
当数据多且字段值有相同的值得时候用普通索引。
-
当字段多且字段值没有重复的时候用唯一索引。
-
当有多个字段名都经常被查询的话用复合索引。
-
普通索引不支持空值,唯一索引支持空值。
-
但是,若是这张表增删改多而查询较少的话,就不要创建索引了,因为如果你给一列创建了索引,那么对该列进行增删改的时候,都会先访问这一列的索引,
-
若是增,则在这一列的索引内以新填入的这个字段名的值为名创建索引的子集,
-
若是改,则会把原来的删掉,再添入一个以这个字段名的新值为名创建索引的子集,
-
若是删,则会把索引中以这个字段为名的索引的子集删掉。
-
所以,会对增删改的执行减缓速度,
-
所以,若是这张表增删改多而查询较少的话,就不要创建索引了。
-
更新太频繁地字段不适合创建索引。
-
不会出现在where条件中的字段不该建立索引。