技术总结(四十一)

server/2024/11/30 7:15:34/

一、MySQL 索引概述

  • 索引的概念:索引就好比一本书的目录,它能帮助 MySQL 快速定位到表中的数据行,而不用全表扫描。通过创建合适的索引,可以大大提高查询的效率。例如,在一个存储了大量员工信息的表中,如果经常要根据员工的工号来查询员工记录,为工号字段创建索引后,数据库就能快速找到对应记录,而不是逐行去检查表中的每一条数据。
  • 索引的类型
    • B-Tree 索引(默认常用的索引类型):它以 B 树数据结构来存储索引数据,适用于全键值、键值范围和键前缀查找等情况。像常见的INTVARCHAR等类型的字段创建索引时,一般就是 B-Tree 索引,比如在一个电商商品表中,对商品编号、商品名称等字段创建的索引往往就是 B-Tree 索引。
    • 哈希索引:基于哈希表实现,只支持等值查询(也就是=<=>操作符),对于范围查询等就不太适用了。例如在一些缓存系统中,如果只是简单地根据某个唯一标识快速查找对应缓存值,哈希索引可能比较合适。不过在 MySQL 中,哈希索引主要是在内存存储引擎(如 Memory 引擎)中使用,InnoDB 和 MyISAM 等常用存储引擎默认的索引不是哈希索引。
    • 全文索引:主要用于在文本类型字段(比如TEXTVARCHAR等较长文本字段)中进行全文搜索,能够帮助查找包含特定关键词的文本内容。例如在一个博客文章表中,要查找包含特定关键词的文章内容,就可以使用全文索引,它支持一些复杂的文本匹配语法,像MATCH AGAINST语句来实现模糊搜索功能。

二、索引优化的原则

  • 选择合适的字段创建索引
    • 经常出现在WHERE子句中的字段:比如在电商订单表中,如果经常根据订单状态(如已支付、已发货等状态)来查询订单,那就应该给订单状态字段创建索引,这样查询满足特定状态的订单时效率会显著提高。
    • 用于连接操作(JOIN)的字段:例如在多表查询中,有订单表和用户表通过用户 ID 进行关联查询,如果在两个表中对应的关联字段(用户 ID)都创建了索引,那么在执行连接操作时数据库就能更快地匹配关联记录,减少数据匹配的时间开销。
    • 字段区分度高的:区分度简单理解就是某个字段不同值的数量占总记录数的比例。像性别字段只有男、女两种值,区分度就很低,如果对它创建索引,在查询时可能并不能很好地缩小查找范围,而身份证号等唯一性高、区分度极高的字段创建索引,对查询效率提升作用明显。
  • 避免过度索引
    • 索引不是越多越好:每一个索引都需要额外的存储空间来保存索引数据,并且在对表进行插入、更新、删除操作时,数据库需要同时维护索引数据的一致性,过多的索引会导致这些操作变得很慢。比如一个简单的小型日志表,本身数据量不大且查询场景很单一,如果创建大量索引,反而会让插入新日志记录的速度变得很慢,影响整体性能。
    • 定期评估索引的有效性:随着业务的发展和数据的变化,有些之前创建的索引可能不再常用或者作用不大了,需要定期去查看索引的使用情况(可以通过数据库的相关性能分析工具查看索引是否被查询使用等情况),对于不再有用的索引进行删除优化。

三、具体的优化策略

  • 复合索引的合理使用
    • 遵循最左前缀原则:如果创建了一个包含多个字段的复合索引(比如在员工表中创建了(name, age, department)这样的复合索引),在查询时,只有按照索引中字段的顺序从左到右使用字段进行条件查询时,索引才会被有效利用。例如WHERE name = '张三' AND age = 30这样的查询能用到复合索引,而WHERE age = 30 AND department = '研发部'就不能完全利用这个复合索引,因为跳过了最左边的name字段。
    • 合理确定复合索引的字段顺序:将区分度高、选择性好且经常用于查询条件的字段放在复合索引的前面。比如在一个学生成绩表中,如果经常根据课程名称和成绩范围来查询学生记录,课程名称的区分度一般比成绩的区分度高(课程种类相对固定,成绩是个数值范围),那创建复合索引时可以写成(course_name, score)这样的顺序。
  • 优化查询语句以更好利用索引
    • 避免在索引字段上使用函数操作:例如在一个存储日期的字段create_date上创建了索引,如果查询语句写成WHERE YEAR(create_date) = 2024,数据库在执行时就无法直接利用索引了,因为对索引字段进行了函数运算。正确的做法是尽量将条件改写成可以直接匹配索引的形式,比如通过日期范围等方式来查询 2024 年的数据(WHERE create_date >= '2024-01-01' AND create_date <= '2024-12-31')。
    • 避免使用OR连接条件(除非每个OR分支都能利用索引):比如WHERE status = 1 OR name = '李四'这样的查询,如果status字段和name字段分别有索引,但是数据库在处理OR连接时往往很难同时有效利用这两个索引,可能会导致全表扫描。可以考虑改写查询逻辑,比如通过UNION操作等方式来分别查询满足不同条件的记录后再合并结果,提高查询效率。
  • 根据数据量和业务场景选择合适的存储引擎及索引策略
    • InnoDB 存储引擎:支持事务、行级锁等特性,适合对数据一致性、并发控制要求高的业务场景。它的索引结构(默认 B-Tree 索引)配合其聚簇索引(主键索引的数据行和索引数据存储在一起)的特点,在很多情况下能高效地支持查询、插入等操作。例如在一个电商系统中,商品表、订单表等核心数据表使用 InnoDB 存储引擎,通过合理创建索引(如对商品的分类字段、订单的用户 ID 字段等创建索引)可以很好地满足业务的查询和更新需求。
    • MyISAM 存储引擎:不支持事务,但是在一些以读为主的简单应用场景中,它的表级锁机制和索引结构(同样有 B-Tree 索引等)在查询性能上也有不错的表现,特别是在数据量不是特别巨大且并发访问不是很复杂的情况下。比如一个小型的企业公告信息表,使用 MyISAM 存储引擎,对公告标题等字段创建索引,方便员工快速查询相关公告内容。

http://www.ppmy.cn/server/146108.html

相关文章

java全栈day10--后端Web基础(基础知识)之续集

一、Servlet执行流程 二、Http协议&#xff08;相对Tomcat和servlet重要一点&#xff09; 2.1Http-概叙 2.2Http-请求协议 2.2.3请求数据格式 2.2.3请求数据获取 先启动服务器 访问/hello Servlet 访问浏览器端Http协议数据 查看数据

《白帽子讲Web安全》15-16章

《白帽子讲Web安全》15-16章 《白帽子讲Web安全》15章15、Web Server配置安全15.1、Apache安全15.2、Nginx安全15.3、jBoss远程命令执行15.4、Tomcat远程命令执行15.5、HTTP Parameter Pollution15.6、小结 第四篇 互联网公司运营安全《白帽子讲Web安全》16章16、互联网业务安全…

解决idea使用maven打包时无法将本地lib库文件和resource目录中的资源文件打包进jar文件的问题!!!

一、问题复现 1&#xff09;项目结构如下 我们看到项目中手动添加了本地lib资源&#xff0c;同时bootspring的配置文件和mapper文件也放在了resouces目录中。 2&#xff09;上述结构的项目在使用maven打包时&#xff0c;最终生成的jar文件中将不包含lib库文件&#xff0c;甚…

泷羽sec-基础之html 学习笔记

声明&#xff01; 学习视频来自B站up主 **泷羽sec** 有兴趣的师傅可以关注一下&#xff0c;如涉及侵权马上删除文章&#xff0c;笔记只是方便各位师傅的学习和探讨&#xff0c;文章所提到的网站以及内容&#xff0c;只做学习交流&#xff0c;其他均与本人以及泷羽sec团队无关&a…

python分析wireshark文件

1 pyshark库 支持wireshark的解析等。 安装pyshark pip install pyshark2 dpkt库 这也是一个用于分析pcap文件的库&#xff0c;是所有分析pcap库中最快的一个。 官方参考文档&#xff1a; https://dpkt.readthedocs.io/en/latest/print_packets.html https://dpkt.readthe…

在Java中使用Apache POI导入导出Excel(三)

本文将继续介绍POI的使用&#xff0c;上接在Java中使用Apache POI导入导出Excel&#xff08;二&#xff09; 使用Apache POI组件操作Excel&#xff08;三&#xff09; 24、拆分和冻结窗格 您可以创建两种类型的窗格;冻结窗格和拆分窗格。 冻结窗格按列和行进行拆分。您创建…

高阶组件HOC:React中的高级技术

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 &#x1f35a; 蓝桥云课签约作者、上架课程《Vue.js 和 E…

(超详细图文)PLSQL Developer 配置连接远程 Oracle 服务

1、下载配置文件 &#xff08;超详细图文详情&#xff09;Navicat 配置连接 Oracle-CSDN博客 将下载的文件解压到单独文件夹&#xff0c;如&#xff1a;D:\App\App_Java\Oracle\instantclient-basic-windows.x64-19.25.0.0.0dbru 2、配置 打开 PLSQL Developer&#xff0c;登…