美文网首页
MySQL 索引(一)

MySQL 索引(一)

作者: 醉鱼java | 来源:发表于2022-03-14 21:45 被阅读0次

MySQL Version

MySQL 8.0.20

索引定义

索引一种特殊的数据结构,为表中的数据行提供快速查找功能,通常通过一个树结构(B树)来表示特定的列,或者一组列的所有值。Innodb引擎中的表有一个表示主键的聚集索引,还可以在一个列或者多个列上创建一个或多个二级索引。根据二级索引的结构,可以分为部分索引(col_name (length)),列索引(col_name),组合索引(col_name1,col_name2,...)

大多数 MySQL 索引(PRIMARY KEY、 UNIQUE、INDEX和 FULLTEXT)都存储在 B-trees中。例外:空间数据类型的索引使用 R-trees;MEMORY 表也支持散列索引;InnoDB使用倒排列表作为FULLTEXT索引

索引类型

主键索引

一种唯一索引,必须指定的是primary key ,一般在创建表的时候指定,也可以通过修改表的方式指定alter table。Innodb要求每个表必须有一个主键索引

唯一索引

这种索引和普通索引基本相同,唯一的一个区别就是索引中所有的值只能出现一次,且必须唯一。如果为列的前缀部分作唯一索引,那列的前缀部分必须是唯一的,如果添加的值已经存在会发生错误

如果一个表中有一个主键索引或者非空的唯一索引且是由单个的整数类型组成的,可以在select语句中使用此索引列_rowid,具体情况如下:

如果主键是由单个整数列组成的,则_rowid指向主键列,如果存在主键,但不是包含单个整数列,则不能使用_rowid

_rowid指定第一个非空唯一索引的列,前提是该索引列是由单个整数类型组成的,如果第一个非空的唯一索引列是不包含单个整数类型的列,则不能使用_rowid

普通索引

普通的索引,没有任何的限制,也是我们常用的索引

全文索引

全文索引仅支持Innodb和MyISAM,并且列的类型只能是char,varchar,text,不支持前缀索引,如果指定了也无效,会被忽略。

空间索引

MyISAM,Innodb,NDB,ARCHIVE 存储引擎支持point和geometry等空间列,但是不同的存储引擎对空间列索引的支持是不同的,空间列的空间和非空间索引可以根据一下规则使用。

空间列上的空间索引具有以下特征:

仅对Innodb和MyISAM引擎生效,为其他引擎指定空间索引会报错

从mysql8.0.12开始,空间列的索引必须是空间索引(SPATIAL),因此SPATIAL关键字是可选的,但是对于空间列上创建索引是隐式的

仅能在单个空间列上创建空间索引,不能在多个列上创建空间索引

索引列不能为空

不能指定列前缀长度,列的整体被加入索引

不能用于主键索引或者唯一索引

InnoDB Storage Engine Index Characteristics

原文链接

参考链接

https://dev.mysql.com/doc/refman/8.0/en/create-index.html

相关文章

  • MySQL索引及查询优化书目录

    MySQL索引的原理之索引目的 MySQL索引的原理之索引原理 MySQL索引的原理之索引的类型 MySQL索引的...

  • MySQL索引的使用

    MySQL索引 MySQL索引可以快速提高MySQL的检索速度。索引分单列索引和组合索引单列索引:即一个索引只包含...

  • 高性能的索引策略

    MySQL查询基础-查询执行过程 MySQL聚簇索引 MySQL覆盖索引 MySQL索引扫描排序 MySQL冗余和...

  • MySQL--索引

    MySQL索引 查看索引 创建索引 创建唯一索引 创建主键索引 删除索引 删除主键 MySQL视图 创建视图 删除...

  • MySql 数据查询优化

    1. MySQL索引类型: mysql的索引有5种:主键索引、普通索引、唯一索引、全文索引、聚合索引(多列索引)。...

  • Mysql索引与锁

    本文以Mysql5.7为例测试。 1:mysql索引方法 Mysql的索引方法分为btree索引和hash索引。 ...

  • MySQL的索引原理与查询优化

    一、MySQL 索引简介 1、 MySQL索引的建立对于MySQL的高效运行是很重要的,索引可以大大提高MySQL...

  • mysql

    1.mysql索引的类型,主键索引、唯一索引、普通索引、组合索引、全文索引,b-tree索引 2.mysql具体有...

  • 索引(二)

    mysql索引的新手入门详解mysql索引之三:索引使用注意规则 索引(Index)是帮助 MySQL 高效获取数...

  • mysql索引总结----mysql 索引类型以及创建(转载)

    一、索引 MySQL索引的建立对于MySQL的高效运行是很重要的,索引可以大大提高MySQL的检索速度 二、索引的...

网友评论

      本文标题:MySQL 索引(一)

      本文链接:https://www.haomeiwen.com/subject/rjfudrtx.html