索引的分类 博客分类: 数据库 数据库索引
首先,了解一下,什么是索引,有哪些索引
索引:如果没有特别指明,都是指B+树结构组织的B-Tree索引。其中聚集索引,次要索引,覆盖索引,复合索引,前缀索引,唯一索引默认都是使用B+树索引,统称索引。
索引分类:
从数据结构角度
1、B+树索引(O(log(n))):关于B+树索引,可以参考 MySQL索引背后的数据结构及算法原理
2、hash索引:
a 仅仅能满足"=","IN"和"<=>"查询,不能使用范围查询
b 其检索效率非常高,索引的检索可以一次定位,不像B-Tree 索引需要从根节点到枝节点,最后才能访问到页节点这样多次的IO访问,所以 Hash 索引的查询效率要远高于 B-Tree 索引
c 只有Memory存储引擎显示支持hash索引
3、FULLTEXT索引(现在MyISAM和InnoDB引擎都支持了)
4、R-Tree索引(用于对GIS数据类型创建SPATIAL索引)
从物理存储角度
1、聚集索引(clustered index)
2、非聚集索引(non-clustered index)
从逻辑角度
1、主键索引:主键索引是一种特殊的唯一索引,不允许有空值
2、普通索引或者单列索引
3、多列索引(复合索引):复合索引指多个字段上创建的索引,只有在查询条件中使用了创建索引时的第一个字段,索引才会被使用。使用复合索引时遵循最左前缀集合
4、唯一索引或者非唯一索引
5、空间索引:空间索引是对空间数据类型的字段建立的索引,MYSQL中的空间数据类型有4种,分别是GEOMETRY、POINT、LINESTRING、POLYGON。MYSQL使用SPATIAL关键字进行扩展,使得能够用于创建正规索引类型的语法创建空间索引。创建空间索引的列,必须将其声明为NOT NULL,空间索引只能在存储引擎为MYISAM的表中创建
推荐阅读
-
索引的分类 博客分类: 数据库 数据库索引
-
spring boot开发web api应用实践(二)操作数据库 博客分类: spring boot 实践笔记 spring bootspring boot 操作数据库
-
数据库安全之* 博客分类: 数据安全 数据库大数据大数据安全
-
数据库安全之军工 博客分类: 数据安全 数据库军工数据安全大数据
-
四川网安政务云 项目案例 博客分类: 数据安全 数据库数据安全数据库安全
-
数据库安全之医疗 博客分类: 数据安全 医疗数据库数据安全
-
数据隐私不仅仅是指机密性 博客分类: 数据安全 数据库数据安全大数据
-
数据库安全之税务 博客分类: 数据安全 防火墙税务数据安全
-
大数据解决方案 博客分类: 数据安全 数据库数据安全大数据大数据安全
-
Percona Xtrabackup数据库备份与还原 博客分类: mysql MySQL