当前位置: 首页 > news >正文

Java面试题11MySQL之执行计划到事务及慢查询

你对MySQL执行计划怎么看

执行计划就是SQL的执行查询的顺序,以及如何使用索引查询,返回的结果集的行数

在MySQL中,我们可以通过explain命令来查看执行计划。其语法如下:

EXPLAIN SELECT * FROM table_name WHERE conditions;

在执行该命令后,MySQL将返回一张表格,用于展示查询的执行计划。其中包括以下几个重要字段:

  • id:每个查询都有一个唯一的id,用于标识这个查询;
  • select_type:表示查询类型,主要分为简单查询、联合查询、子查询等;
  • table:表示查询涉及到的表名;
  • partitions:表示涉及到的分区;
  • type:表示表的访问类型,包括ALL(全表扫描)、index(索引扫描)、range(索引范围扫描)、ref(非唯一索引扫描)、eq_ref(唯一索引扫描)等;
  • possible_keys:表示可用的索引;
  • key:MySQL选择使用的索引;
  • key_len:表示索引字段长度;
  • ref:表示索引被哪个字段或常量所引用;
  • rows:表示MySQL根据表统计信息估算出的查询结果集的行数;
  • filtered:表示通过条件过滤后的结果集占总结果集的百分比;
  • Extra:包含MySQL执行计划中的其他信息,例如是否使用了临时表、是否使用了文件排序等。
  • 执行效率:ALL<index<range<eq_ref<const<system

事务的基本特性和隔离级别

事务的基本特性ACID分别:原子性,一致性,隔离性,持久性。

原子性:指的是一个事务中的操作要么全部成功,要么全部失败。

一致性:指的是数据库总是从一个一致性的状态转换到另外一个一致性的状态。

隔离性:指的是一个事务的修改在最总提交前,对其他事务是不可见的。

持久性:指的是一旦事务提交,所作的修改就会永久保存到数据库中。

隔离级别

read uncommit 读未提交,可能会读到其他事务未提交的数据,也叫脏读

read commit 读已提交,两次读取结果不一致,叫不可重复读,解决脏读问题,

repeatable read 可重复复读,MySQL的默认级别,每次读取结果都一样,但可能产生幻读

serializable 串行,一般不使用,会给每一行读取的数据加锁,导致大量超时和锁竞争的问题

对慢查询都有怎样的优化过

优化首先要清楚慢的原因,查询条件没有命中索引,loadl不需要的数据列,数据量太大?

所以优化也是针对这个三个方向来进行优化的

首先分析语句,是否load了额外的数据,可能时出现呢了多余的行并且抛弃掉了,可能是加载了许多不需要的列,对语句进行分析以及重写

分析语句的执行计划,如何获得使用索引的情况,之后修改语句或者修改索引,使得语句可以尽可能的命中索引

如果对语句的优化无法进行,可以考虑表中的数据量是否太大,进行横向或者纵向的分表

ACID靠什么保证的?

A原子性是由undo log日志保证,他记录了需要回滚的日志信息,事务回滚时撤销以及执行成功的sql

C一致性是由其他三个特性保证,程序代码要保证业务的上的一致性

I隔离性偶MVCC来保证

D持久性由内存+redo log来保证,MySQL修改数据同时在内存和redo log记录这次操作,发生宕机可以从redo log恢复

InnoDB redo log写盘,InnoDB事务进入prepare状态。

如果prepare成功,binlog写盘,再继续将事务日志持久化到binlog,如果持久化成功,那么InnoDB事务则进入commit状态(在redo log里面写入一个commit记录)redo log的刷盘会在系统空闲时进行

http://www.lryc.cn/news/317710.html

相关文章:

  • 算法时空复杂度分析:大O表示法
  • threejs简单创建一个几何体(一)
  • msfconsole数据库连接不了的问题【已解决】
  • 7. Linux进程环境
  • [linux] 静态图和动态图
  • 1.Spring核心功能梳理
  • 活动预告:如何培养高质量应用型医学人才?
  • 蓝桥杯算法错题记录-基础篇
  • Java知识点之单例模式
  • Flutter第三弹:常用的Widget
  • Dynamic Wallpaper v17.4 mac版 动态视频壁纸 兼容 M1/M2
  • Windows / Mac应用程序在Linux系统中的兼容性问题 解决方案
  • Net Core 使用Mongodb操作文件(上传,下载)
  • 适用于系统版本:CentOS 6/7/8的基线安全检测脚本
  • Seata源码流程图
  • 英飞凌电源管理PMIC的安全应用
  • 快速在Linux系统安装MySQL
  • 数据库相关理论知识(有目录便于直接锁定相关知识点+期末复习)
  • NCC环境配置
  • 用python实现Dubins曲线生成
  • 智能技术上的“是”并不代表具体领域的“应该”
  • 永热爱 敢向前 | Paraverse平行云的2023 年终总结
  • c/c++的内存分配,详细说一下栈、堆和静态存储区
  • 每日构造题训练——C. Divan and bitwise operations
  • 【C++练级之路】【Lv.13】多态(你真的了解虚函数和虚函数表吗?)
  • 如何在Windows系统安装Node.js环境并制作html页面发布公网远程访问?
  • C#,数值计算,希尔伯特矩阵(Hilbert Matrix)的算法与源代码
  • 【C++教程从0到1入门编程】第八篇:STL中string类的模拟实现
  • 学生时期学习资源同步-1 第一学期结业考试题6
  • 迁移学习怎么用