C05S11-MySQL数据库索引

一、索引

1. 索引概述

索引是一个排序的列表,在这个列表当中存储了索引的值和这个值对应数据所在的物理地址。使用索引之后,查询数据表时,不用全表扫描来定位数据所在行,而是通过索引直接找到该行数据对应的物理地址,进而访问数据,以提高查询数据的速度。

索引包括普通索引、主键索引、唯一索引、组合索引、全文索引等,主键索引和唯一索引在创建对应的约束后就会自动创建;组合索引是指根据多个字段一起创建索引;全文索引适用于文本的模糊查询。

2. 索引优缺点

索引的优点:

  1. 当数据表的行数较多或者多表查询的时候,使用索引可以提高查询速度。

  2. 降低数据库的I/O成本、排序成本。

  3. 提高表与表之间的连接速度。

  4. 减少分组和排序时间。

  5. 提高数据库的恢复速度。

  6. 可以通过创建唯一索引来保证数据的唯一性。

索引的缺点:

  1. 索引会占据磁盘空间。
  2. 更新数据时消耗的时间会比更新无索引数据表的时间要长。

3. 索引创建原则

索引可以提升数据的查询速度,但并不是所有情况都适合索引。有索引的情况下,数据库会先进行索引查询,然后定位到数据行,如果索引设置不合理,会增加数据库的负担。

  1. 表的主键和外键必须要有索引,默认为索引。
  2. 查询的表条目超过300行以上,可以使用索引。
  3. 与其他关连的字段要设置索引。
  4. 唯一性差的字段不适合设置索引。
  5. 更新频繁的字段不适用于索引。
  6. 频繁用于WHERE子句、GROUP BY子句、ORDER BY子句的字段,要设置索引。、

4. 索引常见操作

  1. 创建普通索引。

    mysql 复制代码
    # 创建数据表时设置
    INDEX 索引名(列名[(length)])
    
    # 创建完数据表时指定
    CREATE INDEX 索引名 ON 表名 (列名[(length)]);
    • length:索引长度,可省略。
  2. 主键索引的创建方式等同于主键约束的创建方式。

  3. 唯一索引除了通过设置唯一约束外,还有下面的创建方法。

    mysql 复制代码
    # 创建数据表时设置
    UNIQUE INDEX 索引名(列名[(length)])
    
    # 创建完数据表时指定
    CREATE UNIQUE INDEX 索引名 ON 表名 (列名[(length)]);
  4. 创建组合索引。

    mysql 复制代码
    # 创建数据表时设置
    INDEX 索引名(列名1[(length)],列名2[(length)]......)
    
    # 创建完数据表时指定
    CREATE INDEX 索引名 ON 表名 (列名1[(length)],列名2[(length)]......);
  5. 创建全文索引。

    mysql 复制代码
    # 创建数据表时设置
    FULLTEXT INDEX 索引名(列名[(length)])
    
    # 创建完数据表时指定
    CREATE FULLTEXT INDEX 索引名 ON 表名 (列名[(length)]);
  6. 删除索引。

    mysql 复制代码
    DROP 索引名 ON 表名;
相关推荐
瓯雅爱分享19 分钟前
Java+Vue构建的采购招投标一体化管理系统,集成招标计划、投标审核、在线竞价、中标公示及合同跟踪功能,附完整源码,助力企业实现采购全流程自动化与规范化
java·mysql·vue·软件工程·源代码管理
迎風吹頭髮1 小时前
Linux内核架构浅谈8-Linux内核与UNIX的传承:设计思想与特性差异
linux·运维·架构
黑马金牌编程2 小时前
Linux 服务器常见的性能调优
linux·运维·服务器·性能优化
jieyu11192 小时前
网络、主机安全扫描工具
linux·安全·系统安全
tianyuanwo2 小时前
Linux进程管理中的T状态问题分析与解决体系
linux·运维·进程管理·t状态
liuyao_xianhui3 小时前
Linux_基本指令1
linux·运维·服务器
咋吃都不胖lyh3 小时前
SQL-多对多关系
android·mysql·数据分析
守望时空333 小时前
Linux挂载NTFS分区指南
linux
shan~~4 小时前
linux达梦数据库操作
linux·数据库·chrome
liliangcsdn4 小时前
LLM时代基于unstructured解析非结构化pdf
linux·服务器·数据分析