我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL优化--概述以及索引优化分析

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL优化--概述以及索引优化分析


	MySQL优化--概述以及索引优化分析
[数据库教程]

一、MySQL概述

1.1、MySQL文件含义

通过如下命令查看

show variables like ‘%dir%‘;

技术图片

MySQL文件位置及含义

名称 备注
basedir /usr/ 安装路径
character_sets_dir /usr/share/mysql-8.0/charsets/ 保存字符集目录
datadir /var/lib/mysql/ 数据存放路径
lc_messages_dir /usr/share/mysql-8.0/
plugin_dir /usr/lib64/mysql/plugin/ 插件
slave_load_tmpdir /tmp 缓存文件
tmpdir /tmp 缓存文件

配置文件位置

Linux:/etc/my.cnf

win:C:ProgramDataMySQLMySQL Server 8.0my.ini

1.2、MySQL主要配置文件

二进制日志log-bin:用于主从复制

错误日志log-error:默认关闭,记录严重警告和错误信息,启动和关闭的详细信息等。

查询日志:默认关闭,可显式指定,记录慢查询日志

数据文件:

  • MyISAM中: 1. frm 存放表结构

    ? 2. myd 存放表数据

    ? 3. myd 存放表索引

  • InnoDB 中:ibd文件存放数据

1.3、MySQL引擎

查询引擎

show engines;

技术图片

show variables like ‘%storage_engine%‘

技术图片

MyISAM InnoDB
构成上的区别: 每个MyISAM在磁盘上存储成三个文件。第一个文件的名字以表的名字开始,扩展名指出文件类型。 .frm文件存储表定义。 数据文件的扩展名为.MYD (MYData)。 索引文件的扩展名是.MYI (MYIndex)。 基于磁盘的资源是InnoDB表空间数据文件和它的日志文件,InnoDB 表的大小只受限于操作系统文件的大小,一般为 2GB
事务处理上方面: MyISAM类型的表强调的是性能,其执行数度比InnoDB类型更快,但是不提供事务支持 InnoDB提供事务支持事务,外部键(foreign key)等高级数据库功能
SELECT、UPDATE、INSERT、Delete操作 如果执行大量的SELECT,MyISAM是更好的选择 1.如果你的数据执行大量的INSERTUPDATE,出于性能方面的考虑,应该使用InnoDB表 2.DELETE FROM table时,InnoDB不会重新建立表,而是一行一行的删除。 3.LOAD TABLE FROM MASTER操作对InnoDB是不起作用的,解决方法是首先把InnoDB表改成MyISAM表,导入数据后再改成InnoDB表,但是对于使用的额外的InnoDB特性(例如外键)的表不适用
AUTO_INCREMENT的操作 每表一个AUTO_INCREMEN列的内部处理。 MyISAMINSERTUPDATE操作自动更新这一列。这使得AUTO_INCREMENT列更快(至少10%)。在序列顶的值被删除之后就不能再利用。(当AUTO_INCREMENT列被定义为多列索引的最后一列,可以出现重使用从序列顶部删除的值的情况)。 AUTO_INCREMENT值可用ALTER TABLE或myisamch来重置 对于AUTO_INCREMENT类型的字段,InnoDB中必须包含只有该字段的索引,但是在MyISAM表中,可以和其他字段一起建立联合索引 更好和更快的auto_increment处理 如果你为一个表指定AUTO_INCREMENT列,在数据词典里的InnoDB表句柄包含一个名为自动增长计数器的计数器,它被用在为该列赋新值。 自动增长计数器仅被存储在主内存中,而不是存在磁盘上 关于该计算器的算法实现,请参考 AUTO_INCREMENT列在InnoDB里如何工作
表的具体行数 select count(*) from table,MyISAM只要简单的读出保存好的行数,注意的是,当count(*)语句包含 where条件时,两种表的操作是一样的 InnoDB 中不保存表的具体行数,也就是说,执行select count(*) from table时,InnoDB要扫描一遍整个表来计算有多少行
表锁 提供行锁(locking on row level),提供与 Oracle 类型一致的不加锁读取(non-locking read in SELECTs),另外,InnoDB表的行锁也不是绝对的,如果在执行一个SQL语句时MySQL不能确定要扫描的范围,InnoDB表同样会锁全表, 例如update table set num=1 where name like "%aaa%"

二、索引优化分析

2.1、什么是索引

MySQL官方的定义为:

索引(Index)是帮助MySQL高效地获取数据的数据结构

索引的本质是数据结构

可简单的理解为“排好序的快速查找数据结构”

2.2、索引分类

索引类型 索引含义
单值索引 一个索引仅包含一个列
唯一索引 索引列的值必须唯一,可以有空值
复合索引 一个索引包含多个列

2.3、基本语法

2.3.1、创建

方法一:

CREATE [UNIQUE] INDEX indexName ON mytable(columnname(length));

方法二:

ALTER mytable ADD [UNIQUE] INDEX [indexname] on (columnname(length));

2.3.2、删除

DROP INDEX [indexName] ON mytable;

2.3.3、查看

SHOW INDEX FROM table_name;

2.4、explain

2.4.1、基本语法

EXPLAIN select语句;

2.4.2、字段解释

  • id:select查询的序列号,包含一组数字,表示select字句或操作表的顺序

    • id相同,执行顺序自上向下
    • id不同,如果是子查询,id的序号会递增,id值越大优先级越高,越先被执行
    • id相同不同,同时存在
  • select_type

    • id select_type 含义
      1 SIMPLE 简单select查询
      2 PRIMARY 包含复杂查询的最外层查询
      3 SUBQUERY 子查询
      4 DERIVED 衍生,递归执行,结果保存至临时表
      5 UNION 若第二个SELECT出现在UNION之后,标记为UNION
      6 UNION RESULT 从UNION表获取结果的SELECT
  • table 这一行的数据关于哪张表

  • partitions

  • type

    • 从最好到最差排序 system>const>eq_ref>ref>range>index>ALL

    • 类型 含义
      system 表中只有一行数据,等于系统表
      const 通过索引一次就找到了,被视为常量
      eq_ref 唯一性索引扫描,表中只有一个记录匹配
      ref 非唯一性索引扫描,表中有多个记录匹配
      range 范围
      index 全索引扫描
      ALL 全表扫描
  • possible_keys

    • 可能会在该表上使用的索引,一个或者多个
    • 查询字段上存在的索引将被列出,不一定实际使用
  • key 实际使用的索引,如果为NULL,未使用索引;若有覆盖索引(从索引就可以获得数据,不需要查表),则仅在key字段出现

  • key_len 索引字段的最大可能长度,并非实际长度

    • 列类型 KEY_LEN 备注
      id int key_len = 4+1 int为4bytes,允许为NULL,加1byte
      id bigint not null key_len=8 bigint为8bytes
      user char(30) utf8 key_len=30*3+1 utf8每个字符为3bytes,允许为NULL,加1byte
      user varchar(30) not null utf8 key_len=30*3+2 utf8每个字符为3bytes,变长数据类型,加2bytes
      user varchar(30) utf8 key_len=30*3+2+1 utf8每个字符为3bytes,允许为NULL,加1byte,变长数据类型,加2bytes
      detail text(10) utf8 key_len=30*3+2+1 TEXT截取部分,被视为动态列类型。
  • ref 引用的字段,为NULL未引用

  • rows 根据表统计信息和索引选用情况,大致估算出所需要读取的行数

  • filtered

  • Extra 不适合包含在其他列但十分重要的信息

    • Using filesort 使用外部排序,不使用索引的排序;无法使用索引完成的排序成为“文件排序”
    • Using temporary 使用了临时表存储中间结果
    • Using index 覆盖索引
    • Using where 使用了where
    • Using join buffer 使用了连接缓存
    • Impossible where 不存在的条件
    • select tables optimized away 没有GROUP BY的情况下,优化MIN/MAX或者对于MyISAM存储引擎优化COUNT(*)操作,查询计划生成阶段即完成优化
    • distinct 使用了distinct

2.5、join语句的优化

  1. 尽可能减少Join语句中的NestedLoop的循环总次数;“ 永远用小结果集驱动大的结果集”。

  2. 优先优化NestedLoop的内层循环;

  3. 保证Join语句中被驱动表上Join条件字段已经被索引;

  4. 当无法保证被驱动表的Join条件字段被索引且内存资源充足的前提下,不要太吝惜JoinBuffer的设置;

MySQL优化--概述以及索引优化分析

原文地址:https://www.cnblogs.com/shimeath/p/13412937.html

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL优化--概述以及索引优化分析

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL优化--概述以及索引优化分析

一、MySQL概述1.1、MySQL文件含义通过如下命令查看show variables like ‘%dir%‘;MySQL文件位置及含义名称值备注basedir/usr/安装路径character_sets_dir/usr/share/mysql-8.0/
MySQL优化--概述以及索引优化分析
2020-07-19

MySQL索引优化实例分析

目录1.数据准备2.实例一3.mysql如何选择合适的索引?4.常见 SQL 深入优化4.1.Order by与Group by优化4.2.分页查询优化4.3.join关联查询优化4.3.1.数据准备4.3.2.MySQL 表关联常见的两种
2022-07-29

MySQL索引优化分享

2,explain的作⽤ 查看表的读取顺序,读取操作类型,有哪些索引可用,表之间关联,每张表中有哪些索引被优化器执⾏3,索引命中策略略分析    最左匹配原则 在索引字段上加入函数(不匹配索引)    is null/is not null/not in(不匹
MySQL索引优化分享
2016-09-28

MySQL索引优化

一、单表创建索引之前:type=ALL全表扫描,Extra里面的Using filesort(文件内部排序)根据where后面的条件创建:CREATE INDEX idx_article_ccv ON article(category_id,comments,
MySQL索引优化
2019-01-06

三、索引优化分析(下)

4. 性能分析 4.1 MySQL 常见性能瓶颈 ① CPU:CPU 在满负荷运行一般发生在数据装入到内存或从磁盘读取数据时; ② IO:磁盘 IO 瓶颈发生在装入数据远大于内存容量时; ③ 服务器硬件瓶颈:通过 top、free、iostat、vmstat
三、索引优化分析(下)
2019-08-11

MySQL优化之索引解析

索引的本质MySQL索引或者说其他关系型数据库的索引的本质就只有一句话,以空间换时间。索引的作用索引关系型数据库为了加速对表中行数据检索的(磁盘存储的)数据结构索引的分类数据结构上面的分类HASH 索引等值匹配效率高不支持范围查找树形索引二叉树,递归二分查找法
MySQL优化之索引解析
2019-07-07

MySQL优化及索引的方法

这篇“MySQL优化及索引的方法”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“MySQL优化及索引的方法”文章吧。索引简单介
2023-06-29

MySQL索引优化EXPLAIN

日常在CURD的过程中,都避免不了跟数据库打交道,大多数业务都离不开数据库表的设计和SQL的编写,那如何让你编写的SQL语句性能更优呢? 先来整体看下MySQL逻辑架构图: MySQL整体逻辑架构图可以分为Server和存储引擎层。 Server层: Ser
MySQL索引优化EXPLAIN
2015-10-24

MySQL优化之索引

SQL为什么需要优化?对于初学者来说,能够写出实现功能的SQL语句而不出错,查询出所需要的结果,就已经能够满足日常使用了。但在某些场景,对性能的要求比较高,因此,要求SQL的执行响应速度快,就需要对SQL进行一定程度的优化。在实际应用场景中,MySQL经常会存
MySQL优化之索引
2021-02-14

MySQL优化(3):索引

MySQL优化中,最重要的优化手段就是索引,也是最常用的优化手段 索引简介:索引:关键字与数据位置之间的映射关系关键字:从数据中提取,用于标识,检索数据的特定内容目的:加快检索 索引检索为什么快:(1)关键字相对于数据本身,量较小(2)关键字都是排序好的 My
MySQL优化(3):索引
2014-05-17

阿里P8架构师谈:MySQL慢查询优化、索引优化、以及表等优化总结

MySQL优化概述 MySQL数据库常见的两个瓶颈是:CPU和I/O的瓶颈。 CPU在饱和的时候一般发生在数据装入内存或从磁盘上读取数据时候。 磁盘I/O瓶颈发生在装入数据远大于内存容量的时候,如果应用分布在网络上,那么查询量相当大的时候那么平瓶颈就
阿里P8架构师谈:MySQL慢查询优化、索引优化、以及表等优化总结
2017-07-17

编程热搜

目录