暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

MySQL索引介绍

原创 亂了乱了 2023-02-01
500

前言

  • 索引种类
  • 索引维护
  • 如何使用索引

一.索引索引种类

MySQL中索引主要包含以下几种:

  1. 普通索引
  2. 唯一索引
  3. 主键索引
  4. 联合索引
  5. 全文索引

二.索引维护

在简述了索引的类型后,再来了解下如何维护索引。
创建语法格式:

CREATE [UNIQUE|FULLTEXT|SPATIAL] INDEX index_name
[index_type]
ON tbl_name (index_col_name,...)
[index_option]
[algorithm_option | lock_option] ...

index_col_name:
    col_name [(length)] [ASC | DESC]

index_option:
    KEY_BLOCK_SIZE [=] value
    | index_type
    | WITH PARSER parser_name
    | COMMENT 'string'

index_type:
    USING {BTREE | HASH}

algorithm_option:
    ALGORITHM [=] {DEFAULT|INPLACE|COPY}

lock_option:
    LOCK [=] {DEFAULT|NONE|SHARED|EXCLUSIVE}

创建索引时,可以指定很多参数:

  1. 可选指定索引的种类,比如:普通、唯一、全文等;
  2. 指定索引加在哪些列上,已经使用的列前缀长度,可选升降序;
  3. 可选指定索引使用的数据结构;
  4. 可选指定索引注释

1.普通索引

创建时,不指定索引种类,默认为普通索引,普通索引无任何限制。

1)创建普通索引
1.直接创建:

CREATE INDEX index_name ON table(column(length))

2.修改表结构进行创建:

ALTER TABLE table_name ADD INDEX index_name ON (column(length))

3.新建表时创建:

CREATE TABLE table (
    id int(11) NOT NULL AUTO_INCREMENT ,
    title char(255) CHARACTER NOT NULL ,
    content text CHARACTER NULL ,
    time int(10) NULL DEFAULT NULL ,
    PRIMARY KEY (`id`),
    INDEX index_name (title(length))
)

2)删除普通索引

DROP INDEX index_name ON table  

2.唯一索引

唯一索引在普通索引的基础上加上了唯一性限制,即索引的列值必须是唯一的,运行列为null。如果是联合在多个列上,多个列联合的值必须唯一。

1)创建唯一索引
1.直接创建:

CREATE UNIQUE INDEX indexName ON table(column(length))

2.修改表结构创建:

ALTER TABLE table_name ADD UNIQUE indexName ON (column(length))

3.新建表时创建:

CREATE TABLE `table` (
    id int(11) NOT NULL AUTO_INCREMENT ,
    title char(255) CHARACTER NOT NULL ,
    content text CHARACTER NULL ,
    time int(10) NULL DEFAULT NULL ,
    UNIQUE indexName (title(length))
)

2)删除唯一索引

DROP INDEX index_name ON table

3.主键索引

表主键上的索引被称为主键索引,主键索引不能单独被创建,且一张表中主键索引只能存在一个。
主键索引是在表创建指定主键时创建的:

CREATE TABLE table (
    id int(11) NOT NULL AUTO_INCREMENT ,
    title char(255) CHARACTER NOT NULL ,
    content text CHARACTER NULL ,
    time int(10) NULL DEFAULT NULL ,
    PRIMARY KEY (`id`),
)    

4.联合索引

联合索引即在多个列上共同创建一个索引,上述创建索引的语法中,被索引的列是可多选。查询中至少需要使用被索引的第一个字段试,索引才会生效。联合索引也遵循最左前缀。

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论