• MySql第三篇---索引的创建与设计原则


    MySql第三篇—索引的创建与设计原则

    索引的声明与使用

    索引的分类

    MySQL的索引包括普通索引、唯一性索引、全文索引、单列索引、多列索引和空间索引等。
    1.从功能逻辑上来说,索引主要有4种,分别是普通索引,唯一索引,主键索引,全文索引。
    2.按照 物理实现方式 ,索引可以分为 2 种: 聚簇索引和非聚簇索引
    3.按照 作用字段个数进行划分,分成单列索引和联合索引

    在这里插入图片描述

    创建索引

    1.创建表的时候创建索引

    CREATE TABLE dept(
    dept_id INT PRIMARY KEY AUTO_INCREMENT,
    dept_name VARCHAR(20)
    );
    CREATE TABLE emp(
    emp_id INT PRIMARY KEY AUTO_INCREMENT,
    emp_name VARCHAR(20) UNIQUE,
    dept_id INT,
    CONSTRAINT emp_dept_id_fk FOREIGN KEY(dept_id) REFERENCES dept(dept_id)
    );
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    在这里插入图片描述

    1. 创建普通索引
    在这里插入图片描述
    在这里插入图片描述

    2. 创建唯一索引
    在这里插入图片描述
    在这里插入图片描述
    3. 主键索引
    在这里插入图片描述
    在这里插入图片描述

    4.创建单列索引

    在这里插入图片描述

    5.创建组合索引
    在这里插入图片描述

    6.创建全文索引
    在这里插入图片描述
    在这里插入图片描述

    7. 创建空间索引
    在这里插入图片描述

    在已经存在的表上创建索引

    在已经存在的表中创建索引可以使用ALTER TABLE语句或者CREATE INDEX语句。如下图:
    在这里插入图片描述
    案例如下图:
    在这里插入图片描述
    在这里插入图片描述

    删除索引

    在这里插入图片描述
    案例如下图:
    在这里插入图片描述

    索引的设计原则

    哪些情况适合创建索引?

    1. 字段的数值有唯一性的限制

    业务上具有唯一特性的字段,即使是组合字段,也必须建成唯一索引
    说明:不要以为唯一索引影响了 insert 速度,这个速度损耗可以忽略,但提高查找速度是明显的。

    2. 频繁作为 WHERE 查询条件的字段

    某个字段在SELECT语句的 WHERE 条件中经常被使用到,那么就需要给这个字段创建索引了。尤其是在数据量大的情况下,创建普通索引就可以大幅提升数据查询的效率。
    比如student_info数据表(含100万条数据),假设我们想要查询 student_id=123110 的用户信息。

    3. 经常 GROUP BY 和 ORDER BY 的列

    索引就是让数据按照某种顺序进行存储或检索,因此当我们使用 GROUP BY 对数据进行分组查询,或者使用 ORDER BY 对数据进行排序的时候,就需要 对分组或者排序的字段进行索引 。如果待排序的列有多个,那么可以在这些列上建立 组合索引 。

    4. UPDATE、DELETE 的 WHERE 条件列

    对数据按照某个条件进行查询后再进行 UPDATE 或 DELETE 的操作,如果对 WHERE 字段创建了索引,就能大幅提升效率。原理是因为我们需要先根据 WHERE 条件列检索出来这条记录,然后再对它进行更新或删除。如果进行更新的时候,更新的字段是非索引字段,提升的效率会更明显,这是因为非索引字段更新不需要对索引进行维护。

    5.DISTINCT 字段需要创建索引
    在这里插入图片描述

    6. 在多个字段都要创建索引的情况下,联合索引优于单值索引

    7.使用最频繁的列放到联合索引的左侧
    因为索引匹配的时候有一个最左匹配原则。

    限制索引的数目

    在实际工作中,我们也需要注意平衡,索引的数目不是越多越好。我们需要限制每张表上的索引数量,建议单张表索引数量不超过6个。原因:
    ① 每个索引都需要占用磁盘空间,索引越多,需要的磁盘空间就越大。
    ② 索引会影响INSERT、DELETE、UPDATE等语句的性能,因为表中的数据更改的同时,索引也会进行调整和更新,会造成负担。
    ③优化器在选择如何优化查询时,会根据统一信息,对每一个可以用到的索引来进行评估,以生成出一个最好的执行计划,如果同时有很多个索引都可以用于查询,会增加MySQL优化器生成执行计划时间,降低查询性能。

    哪些情况不适合创建索引?

    1. 在where中使用不到的字段,不要设置索引

    WHERE条件(包括GROUP BY、ORDER BY)里用不到的字段不需要创建索引,索引的价值是快速定位,如果起不到定位的字段通常是不需要创建索引的。

    2. 数据量小的表最好不要使用索引

    如果表记录太少,比如少于1000个,那么是不需要创建索引的。表记录太少,是否创建索引对查询效率的影响并不大。甚至说,查询花费的时间可能比遍历索引的时间还要短,索引可能不会产生优化效果。

    3. 有大量重复数据的列上不要建立索引

    在条件表达式中经常用到的不同值较多的列上建立索引,但字段中如果有大量重复数据,也不用创建索引。比如在学生表的"性别"字段上只有“男”与“·女"两个不同值,因此无须建立索引。如果建立索引,不但不会提高查询效率,反而会严重降低数据更新速度。

    4.避免对经常更新的表创建过多的索引

    第一层含义: 频繁更新的字段不一定要创建索引。因为更新数据的时候,也需要更新索引,如果索引太多,在更新索引的时候也会造成负担,从而影响效率。
    第二层含义: 避免对经常更新的表创建过多的索引,并且索引中的列尽可能少。此时,虽然提高了查询速度,同时却会降低更新表的速度

    5.不建议用无序的值作为索引

    例如身份证、UUID(在索引比较时需要转为ASCII,并且插入时可能造成页分裂)、MD5、HASH、无序长字符串等。

    6.删除不再使用或者很少使用的索引

    表中的数据被大量更新,或者数据的使用方式被改变后,原有的一些索引可能不再需要。数据库管理员应当定期找出这些索引,将它们删除,从而减少索引对更新操作的影响。

    小结

    索引是一把双刃剑,可提高查询效率,但也会降低插入和更新的速度并占用磁盘空间。选择索引的最终目的是为了使查询的速度变快,上面给出的原则是最基本的准则,但不能拘泥于上面的准则,在以后的学习和工作中进行不断的实践,根据应用的实际情况进行分析和判断,选择最合适的索引方式。

  • 相关阅读:
    9.1.tensorRT高级(4)封装系列-自动驾驶案例项目self-driving-道路分割分析
    day 4
    说说你了解的 Nginx
    leetcode字符串必刷题——反转字符串、反转字符串 II、反转字符串中的单词、找出字符串中第一个匹配项的下标、重复的子字符串
    用DIV+CSS技术设计的网上书城网页与实现制作(大一Web课程设计)
    Global Terrorism Database
    聊聊绩效考核:松松网编辑跑路了吗?
    Java 第三阶段增强分析需求,代码实现能力【网络编程】
    面向对象程序设计1-类的定义和使用
    警惕智能手机的“隐形眼”:如何保护我们的数字隐私堡垒
  • 原文地址:https://blog.csdn.net/qq_45950109/article/details/133989545