数据库中的索引就像一本书的目录,可以据此快速定位数据库中相关数据的所在位置。
在数据库中,索引被定义为一种特殊的数据结构,由数据库中的一列或多列组合而成,可以用来快速查询数据表中某一特定值的记录。
索引是在表的字段的基础上建立的一种数据库对象,它由DBA或者表的拥有者创建或撤销,他是创建表与表之间关联关系的基础。
普通索引是MySQL中的基本索引类型,允许在定义索引的列中插入空值和重复值。
创建普通索引的几种方式:
# 1.直接创建索引
create index index_name on table(column(length));
# 2. 以修改表结构创建
alter table table_name add index index_name on column(length);
# 3. 创建表的同时创建索引
create table user(
id CHAR(6) not null,
name CHAR(255) not null,
primary key(id),
index user_name(name(length));
)
唯一索引指索引列的值必须唯一,但允许有空值。如果是组合索引,则列值的组合必须唯一。
创建唯一索引的几种方式:
# 1.直接创建索引
create unique index index_name on table(column(length));
# 2. 以修改表结构创建
alter table table_name add unique index index_name on column(length);
# 3. 创建表的同时创建索引
create table user(
id CHAR(6) not null,
name CHAR(255) not null,
primary key(id),
unique index user_name(name(length));
)
主键索引是一种特殊的唯一索引,一个表只能有一个主键,不允许有空值。
全文索引的类型为FULLTEXT,表示在定义索引的列上支持值的全文查找,允许插入重复值或空值。
全文索引主要用来查找文本中的关键字,而不是直接与索引中的值相比较。
MySQL中只有MyISAM存储引擎支持全文索引。
全文索引可以在进行创建表、更新表和创建索引时使用,目前只支持CHAR、VARCHAR、TEXT列创建全文索引。
聚集索引 | 非聚集索引 |
---|---|
一个表只能有一个 | 一个表可以有多个 |
物理连续 | 逻辑连续,物理不连续 |
查询快,插入慢(需要移动物理位置) | 回表查询 |
索引的叶节点就是数据节点 | 索引的叶节点仍然是索引节点,通过一个指针指向对应的数据块。 |
(1)包含太多重复值的字段。
(2)查询中很少被引用的字段。
(3)值特别长的字段。
(4)查询返回率很高的字段。
(5)具有很多NULL值的字段。
(6)需要经常增、删、改的字段。
(7)记录较少的基本表。
(8)需要频繁、大批量进行数据更新的基本表。
create table <table_name> [<fields_name> type]
[UNIQUE|FULLTEXT][INDEX|KEY]
<index_name> (<column_name > [length]) [ASC|DESC]
show index from <table_name> [from <database_name>]
drop index <index_name> from <table_name>
alter table <table_name> drop index <index_name>
版权说明 : 本文为转载文章, 版权归原作者所有 版权申明
原文链接 : https://wang11.blog.csdn.net/article/details/126305448
内容来源于网络,如有侵权,请联系作者删除!