加入收藏 | 设为首页 | 会员中心 | 我要投稿 南平站长网 (https://www.0599zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

MySQL 索引(一)

发布时间:2022-10-25 00:30:32 所属栏目:MySql教程 来源:网络
导读: MySQL Version
MySQL 8.0.20
索引定义
索引一种特殊的数据结构,为表中的数据行提供快速查找功能,通常通过一个树结构(B树)来表示特定的列,或者一组列的所有值。Innodb引擎中的表有一个

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要求每个表必须有一个主键索引

mysql表索引_mysql表看加索引_mysql索引表

唯一索引

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

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

普通索引

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

全文索引

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

空间索引

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

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

InnoDB Storage Engine Index Characteristics

mysql表索引_mysql索引表_mysql表看加索引

参考链接

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

(编辑:南平站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!