mysql 有哪些索引
Mysql支持哪几种索引
从数据结构角度
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的表中创建
CREATE TABLE table_name[col_name data type]
[unique|fulltext|spatial][index|key][index_name](col_name[length])[asc|desc]
1、unique|fulltext|spatial为可选参数,分别表示唯一索引、全文索引和空间索引;
2、index和key为同义词,两者作用相同,用来指定创建索引
3、col_name为需要创建索引的字段列,该列必须从数据表中该定义的多个列中选择;
4、index_name指定索引的名称,为可选参数,如果不指定,MYSQL默认col_name为索引值;
5、length为可选参数,表示索引的长度,只有字符串类型的字段才能指定索引长度;
6、asc或desc指定升序或降序的索引值存储
相关文章
- mysql索引总结(3)-MySQL聚簇索引和非聚簇索引
- VS2013与MySql建立连接;您的项目引用了最新实体框架;但是,找不到数据链接所需的与版本兼容的实体框架数据库 EF6使用Mysql的技巧
- mysql二级索引
- 群友讨论:Pandas与MySQL求解经销商会话时间相关的问题
- 数据库表设计时一对一关系存在的必要性 数据库一对一、一对多、多对多设计 面试逻辑题3.31 sql server 查询某个表被哪些存储过程调用 DataTable根据字段去重 .Net Core Cors中间件解析 分析MySQL中哪些情况下数据库索引会失效
- 【MySQL高级】索引优化
- 【MySQL高级】Mysql的体系结构概览及存储引擎以及索引的使用
- mysql启动时报错:Starting MySQL... ERROR! The server quit without updating PID file (/opt/mysql/data/mysql.pid) 的解决方法
- 和面试官聊了半小时的MySQL索引。
- 【MySQL进阶-07】深入理解mysql性能优化以及解决慢查询问题
- 【MySQL进阶-01】深入理解mysql索引本质
- mysql 几阶b树_在学到MySQL索引时,涉及到了B树和B+树.聊一聊
- MySQL索引下推
- mysql索引有哪些类型?
- MySQL索引原理以及查询优化
- mysql中联合索引的细节问题
- mysql中int型的数字怎么转换成字符串
- MySQL 优化之 ICP (index condition pushdown:索引条件下推)
- MySQL 优化之 index merge(索引合并)
- Mysql 存储引擎中InnoDB与Myisam的主要区别
- 转 【MySQL】常用拼接语句 shell 下执行mysql 命令
- pt-heartbeat工具监控MySQL复制延迟
- mysql 索引
- mysql 索引优化,索引建立原则和不走索引的原因
- 别只守着MySQL,PostgreSQL基本运维都在这里了
- 猫眼电影爬取(三):requests+pyquery,并将数据存储到mysql数据库
- Mysql Cluster7.5.6在 windows10 部署安装
- 【MySql 】is not allowed to connect to this MySql server 无法访问远程MySQL数据库
- 高性能 MySQL(七):11个高性能的索引策略