MySQL创建高性能的索引(三)

2024-09-07 10:58

本文主要是介绍MySQL创建高性能的索引(三),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

MySQL创建高性能的索引

  • MySQL
    • 索引基础
      • B-Tree索引适用的查询类型
      • B-Tree注意事项
    • 索引分类和区别
      • B-Tree索引
      • Hash索引
      • 空间索引
      • 全文索引
    • 索引注意事项
    • 聚簇索引
    • 索引覆盖

MySQL

索引是存储引擎快速找到记录的一种数据结构。使用索引可以极大的提高MYSQL的查询性能,接下来讲介绍索引的基础索引的分类和区别索引的注意事项、以及关于聚簇索引覆盖索引的知识点。

索引基础

当你去看一本书,如何快速找到你想打开的页? 你一定会先看书的索引部分,在根据索引的页码数直接定位到目标页。相比你一页页的去翻看极大的节省了时间。

MYSQL的索引也是同样的原理,当我们创建某个索引时,MYSQL会为我们维护一套索引树,MYSQL的索引是在存储引擎层面实现的,所以不同的存储引擎,索引存储的数据结构也不相同,Innodb使用的是B+Tree的数据结构,是B-Tree的一种变种。

B-Tree索引适用的查询类型

  1. 全值匹配,指索引是1个或者n个字段组合,所有索引字段参与匹配查询
  2. 匹配最左前缀,指索引是n个字段组合,需要从最左前缀进行匹配
  3. 匹配列前缀,指索引可以使用索引字段,like匹配前缀内容,如like ‘abc%’
  4. 精确匹配某一列并范围匹配另外一列
  5. 只访问索引查询,这种就是覆盖查询,只会遍历索引,不会访问数据行

B-Tree注意事项

  1. 多列索引必须按照最左前缀匹配,否则无法应用索引
  2. 多列索引中不能跳过索引列,比如A,B,C字段三个列组合索引,如果查询使用where A=1 and C=1,则只会使用A列索引
  3. 多列索引中范围查询的某个列,后面的字段都无法使用索引查询,如果范围查询有限,可以使用IN代替
  4. Like匹配不可以使用like ‘%123’,不会走索引,而like ‘123%’可以走索引

索引分类和区别

索引主要分B-Tree、Hash索引、全文索引、空间数据索引

B-Tree索引

  1. B-Tree索引是有序排列,非常适合范围查询、排序
  2. B-Tree多列组合索引,排序按照列的顺序排序
  3. B-Tree索引支持全值匹配、匹配最左前缀、匹配列前缀、精确匹配某一列范围匹配另外一个列、只访问索引数据(索引覆盖查询)
  4. B-Tree不能索引非最左前缀、不能跳过索引列、查询有某个列范围查询,则后面的查询无法使用索引查询(可以使用等于条件代替范围查询)

Hash索引

  1. 基于哈希表实现,需要精准匹配
  2. 不支持范围、部分查询,不支持排序,
  3. hash冲突使用链表法
  4. Innodb支持自适应hash索引,即当MYSQL发现某些索引频繁使用时,基于内存创建Hash索引

空间索引

空间索引一般做地理数据存储,一般用的不多

全文索引

索引比较特殊,它查找是文本中的关键词,而不是比较索引中的值,实现比较复杂,一般使用搜索引擎(Elasticsearch)代替

索引注意事项

  1. 索引不能有表达式、函数参与,否则无法使用索引,且无法应用查询缓存
  2. 多列索引应该注意索引的顺序,一般选择性较高的放在第一列
  3. 注意某个列是否出现相同的值频率比较高,比如用户名默认设置guest,导致在某种查询(查询等于guest)会趋于扫描全表的性能
  4. 对于索引字段过长,可以使用hash索引代替

聚簇索引

聚簇索引并不是单独的一种索引类型,而是一种索引的存储方式,
聚簇索引叶子页会包括数据行所有的列,节点页只包含索引列。

MYSQL会选择主键作为聚簇索引,如果没有主键会选择唯一非空索引,否则MYSQL会隐式创建一个主键索引

优点:

  1. 访问数据更快。因为索引数据都保存在B-tree树上,无需在去获取数据行数据
  2. 使用覆盖索引扫描查询可以直接使用页节点中的主键值

缺点:

  1. 更新速度严重依赖插入顺序
  2. 更新聚簇索引代价比较高,会强制InnoDB把每个被更新的行移动到新的位置
  3. 更新移动的同时,有可能会产生页分裂,因为移动的新位置原本的页已经满了,需要分裂页进行存储

索引覆盖

索引覆盖是一种优化方式,当查询的列是索引全部覆盖的列,则只会查询索引树,无需再回表查询;

比如对于分页偏移量比较大的情况,如limit 100000,20, MYSQL需要先查询100020条数据,在取20条,偏移量越大越影响性能;

因此可以采用覆盖索引的方式;
x = select id from table where id > 100000 limit 20;
在查询select * from table where id in (x);

上面的方式依赖于自增主键的形式,同时记录列上次的浏览记录。

本文如有任何问题,请留言指教,以免误导他人

这篇关于MySQL创建高性能的索引(三)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1144874

相关文章

SQL中的外键约束

外键约束用于表示两张表中的指标连接关系。外键约束的作用主要有以下三点: 1.确保子表中的某个字段(外键)只能引用父表中的有效记录2.主表中的列被删除时,子表中的关联列也会被删除3.主表中的列更新时,子表中的关联元素也会被更新 子表中的元素指向主表 以下是一个外键约束的实例展示

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

如何去写一手好SQL

MySQL性能 最大数据量 抛开数据量和并发数,谈性能都是耍流氓。MySQL没有限制单表最大记录数,它取决于操作系统对文件大小的限制。 《阿里巴巴Java开发手册》提出单表行数超过500万行或者单表容量超过2GB,才推荐分库分表。性能由综合因素决定,抛开业务复杂度,影响程度依次是硬件配置、MySQL配置、数据表设计、索引优化。500万这个值仅供参考,并非铁律。 博主曾经操作过超过4亿行数据

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

MySQL高性能优化规范

前言:      笔者最近上班途中突然想丰富下自己的数据库优化技能。于是在查阅了多篇文章后,总结出了这篇! 数据库命令规范 所有数据库对象名称必须使用小写字母并用下划线分割 所有数据库对象名称禁止使用mysql保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来) 数据库对象的命名要能做到见名识意,并且最后不要超过32个字符 临时库表必须以tmp_为前缀并以日期为后缀,备份

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定

Java 创建图形用户界面(GUI)入门指南(Swing库 JFrame 类)概述

概述 基本概念 Java Swing 的架构 Java Swing 是一个为 Java 设计的 GUI 工具包,是 JAVA 基础类的一部分,基于 Java AWT 构建,提供了一系列轻量级、可定制的图形用户界面(GUI)组件。 与 AWT 相比,Swing 提供了许多比 AWT 更好的屏幕显示元素,更加灵活和可定制,具有更好的跨平台性能。 组件和容器 Java Swing 提供了许多

[MySQL表的增删改查-进阶]

🌈个人主页:努力学编程’ ⛅个人推荐: c语言从初阶到进阶 JavaEE详解 数据结构 ⚡学好数据结构,刷题刻不容缓:点击一起刷题 🌙心灵鸡汤:总有人要赢,为什么不能是我呢 💻💻💻数据库约束 🔭🔭🔭约束类型 not null: 指示某列不能存储 NULL 值unique: 保证某列的每行必须有唯一的值default: 规定没有给列赋值时的默认值.primary key: