mysql深层剖析_MySQL深层理解,执行流程

MySQL是一个关系型数据库,关联的数据保存在不同的表中,增加了数据操作的灵活性。

执行流程

MySQL是一个单进程服务,每一个请求用线程来响应,

流程:

1,客户请求,服务器开辟一个线程响应用户。

2,用户发起SQL请求,

3,查询缓存,并记录用户SQL,如果再次查询,直接查缓存。

4,没有缓存,进入分析器,

语法分析器:检查语法

词法分析器:将命令切片,按空格隔开,获取表,内容和用户权限。

5,优化执行路径选择,生产执行树.

6,存储引擎:用于管理存储文件系统,给上层应用提供不同管理。

那么什么是存储引擎呢?

存储引擎说白了就是如何存储数据、如何为存储的数据建立索引和如何更新、查询数据等技术的实现方法。因为在关系数据库中数据的存储是以表的形式存储的,所以存储引擎也可以称为表类型(即存储和操作此表的类型)。在Oracle 和SQL Server等数据库中只有一种存储引擎,所有数据存储管理机制都是一样的。而MySql数据库提供了多种存储引擎。用户可以根据不同的需求为数据表选择不同的存储引擎,用户也可以根据自己的需要编写自己的存储引擎。

常用的存储引擎:

myisam

MyISAM是默认存储引擎。它基于更老的ISAM代码,但有很多有用的扩展。(注意MySQL 5.1不支持ISAM)。 每个MyISAM在磁盘上存储成三个文件。第一个文件的名字以表的名字开始,扩展名指出文件类型。.frm文件存储表定义。数据文件的扩展名为·MYD (MYData)。

二进制文件,可以在不同系统上用

InnoDB

1.3.1、innodb存储引擎,特点支持外键、行锁、非锁定读(默认情况下读取不会产生锁)、mysql-4.1开始支持每个innodb引擎的表单独放到一个表空间里。innodb通过使用MVCC多版本并发控制 来获取高并发性,并且实现sql标准的4种隔离级别,同时使用一种被称成next-key locking的策略来避免换读(phantom)现象。除此之外innodb引擎还提供了插入缓存(insert buffer)、二次写(double write)、自适应哈西索引(adaptive hash index)、预读(read ahead)等高性能技术。

1.3.2、myisam存储引擎,myisam特点是不支持事物,适合olap应用,myisam表由MYD和MYI组成。mysql-5.0版本之前,myisam默认支持的表大小为4G,从mysql-5.0以后,myisam默认支持256T的表单数据。myisam只缓存索引数据。

二.InnoDB存储引擎

2.2、innodb引擎架构

InnoDB的多个内存块组成了内存池,负责如下工作:

1).维护所有进程/线程需要访问的多个内部数据结构。

2).缓存磁盘上的数据,方便快速的读取,并且在对磁盘文件的数据进行修改之前在这里缓存。

3).重做日志缓存。

后台线程的主要作用是负责刷新内存池中的数据,保证缓冲池中的内存缓存是最近的数据,此外、将已经修改的数据文件刷新到磁盘文件

2.2.1、后台线程

innodb存储引擎后台有7个线程,—–4个IO线程(insert buffer thread,log thread,read thread,write thread),1个master thread,一个lock监控线程,一个错误监控线程。

2.2.2、内存

innodb存储引擎内存由以下三个部分组成:缓冲池(buffer pool),重做日志缓存(redo log buffer),额外的内存池(additional memory pool)。可以使用 show engine innodb status来查看innodb_buffer_pool的使用情况。

innodb_buffer_pool_size:具体看,缓冲池中的数据库类型有:索引页、数据库页、undo页、插入缓存页(insert buffer)、自适应hash(adaptive hashindex)、innodb存储的锁信息(lock info)、数据字典信息(data dictionary)。

InnoDB工作方式:将数据文件按页(每页16K)读入InnoDBbuffer pool,然后按最近最少使用算法(LRU)保留缓存数据,最后通过一定频率将脏页刷新到文件。

被InnoDB存储引擎管理的两个重要的基于磁盘的资源是InnoDB表空间数据文件和它的日志文件。

如果你指定无InnoDB配置选项,MySQL将在MySQL数据目录下创建一个名为ibdata1的10MB大小的自动扩展

数据文件,以及两个名为ib_logfile0和ib_logfile1的5MB大小的日志文件。

回答: 深层的SQL排名语句可以通过使用EXPLAIN来进行分析。EXPLAIN是一个模拟优化器执行SQL查询语句的工具,它可以帮助我们分析查询语句或表结构的性能瓶颈。通过执行"EXPLAIN + SQL语句"的方式,我们可以获取以下信息:表的读取顺序、数据读取操作的操作类型、哪些索引可以使用、哪些索引被实际使用、表之间的引用、每张表有多少行被优化器查询等等。\[1\] 此外,为了更好地理解SQL的写法是否合理,我们可以参考手写SQL顺序和机读SQL顺序。手写顺序是指按照一定的顺序编写SQL语句,如select、from、join、where、group by、having、order by、limit等。而机读SQL顺序是指根据执行计划中的id值来确定执行顺序,id值越大的越先执行。如果id相同,则按照自上而下的顺序执行。如果id有相同又有不同的情况,则先执行值大的,值相同的按照自上而下的顺序执行。\[2\]\[3\] 总之,通过使用EXPLAIN和参考手写SQL顺序以及机读SQL顺序,我们可以更好地理解和优化深层的SQL排名语句。 #### 引用[.reference_title] - *1* *2* *3* [mysql的sql语句优化基本要点](https://blog.csdn.net/qq_41253573/article/details/122433711)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值