最常用,没有任何限制。
必须唯一,但允许空值,如果是组合索引,列值的组合必须唯一。
由于MySQL查询时,只能使用一个索引,因此建立组合索引在组合查询的场景下更加有效。组合索引是有顺序的,建立一个组合索引,其实相当于建立了所有该索引包含的前缀的索引,举例说明为,建立组合索引(id,time)相当于分别建立了(id,time)和(id)两个索引。
MySQL中的主键是聚集索引(innoDB)。一个表只能有一个聚集索引,按照B+树的方式存放,子节点就是数据。
非聚集索引指向聚集索引,因此聚集索引更加直接。
建立索引可以大大提高查询速度,但是同时也会降低插入,更新和删除的效率(因为要维护B+树),索引也会占用一定的空间,索引过多则索引文件会膨胀很快。
因此,以下情况不要用索引
索引失效的7种情况
聚集索引与非聚集索引的总结
mysql索引总结----mysql索引类型以及创建
原文:https://www.cnblogs.com/cielosun/p/11503121.html