C05S11-MySQL数据库索引

embedded/2024/12/21 12:09:37/

一、索引

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 表名;
    

http://www.ppmy.cn/embedded/147528.html

相关文章

mybatisPlus使用步骤详解

1.导包&#xff1a; <!--mybatis-plus jar文件--><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.5.1</version></dependency> yml和之前的相比多了一个-…

浅谈Java注解之SpringBootApplication

一、SpringBootApplication的介绍 SpringBootApplication是一个组合注解&#xff0c;由Configuration、EnableAutoConfiguration和ComponentScan这三个注解组合而成。它的主要作用是标注一个 Java 类作为 Spring Boot 应用程序的启动类&#xff0c;当运行该类的main方法时&…

【HarmonyOS NEXT】Web 组件的基础用法以及 H5 侧与原生侧的双向数据通讯

关键词&#xff1a;鸿蒙、ArkTs、Web组件、通讯、数据 官方文档Web组件用法介绍&#xff1a;文档中心 Web 组件加载沙箱中页面可参考我的另一篇文章&#xff1a;【HarmonyOS NEXT】 如何将rawfile中文件复制到沙箱中_鸿蒙rawfile 复制到沙箱-CSDN博客 目录 如何在鸿蒙应用中加…

【vue2+js】记录如何校验一组数据中是否有区间重叠

界面样子 html代码片段 <template><div class"threshold-wrap"><el-form class"threshold-list" ref"form"><span v-for"(v, vIndex) in thresholdList" :key"v.id"><el-form-item prop…

【设计模式】空接口

&#xff08;空&#xff09;接口的用法总结 接口用于定义某个类的特定能力或特性。在工作流或任务管理系统中&#xff0c;接口可以帮助标识哪些任务可以在特定阶段执行。通过实现这些接口&#xff0c;任务类可以被标识为在相应的阶段可以执行&#xff0c;从而在验证和执行逻辑…

vue create 创建项目 提示 Failed to check for updates 淘宝 NPM 镜像站喊你切换新域名啦

1、使用 vue create demo创建项目的时候发现 提示 “Failed to check for updates”&#xff0c; 执行 npm config list 看了一下 镜像源是&#xff1a;https://registry.npm.taobao.org 然后搜索一下发现这个淘宝这个镜像域名切换了。 公告地址&#xff1a;【公告】淘宝 npm …

WebMvcConfigurer和WebMvcConfigurationSupport(MVC配置)

一:基本介绍 WebMvcConfigurer是接口&#xff0c;用于配置全局的SpringMVC的相关属性&#xff0c;采用JAVABean的方式来代替传统的XML配置文件&#xff0c;提供了跨域设置、静态资源处理器、类型转化器、自定义拦截器、页面跳转等能力。 WebMvcConfigurationSupport是webmvc的…

【C语言】打牌游戏

相信你是最棒哒&#xff01;&#xff01;&#xff01; 文章目录 题目描述 正确代码 总结 题目描述 Suneet 和 Slavic 玩一个卡牌游戏。游戏规则如下&#xff1a; 每张卡片的整数值在 1 和 10之间。每位玩家获得 2 张面朝下的卡片&#xff08;因此玩家不知道自己的卡片&#…