当前位置: 首页 > news >正文 好用的网站链接网站模板手机 news 2025/11/6 0:35:38 好用的网站链接,网站模板手机,网站建设高端培训,建设招标网网站一.知识回顾 之前的文章我们一起学习了MySQL面试必问系列之事务专题、锁专题#xff0c;没有学习的小伙伴可以直接通过该链接地址直接访问#xff0c;MYSQL你真的了解吗专栏的文章#xff0c;接下来我们就一起来学习一下MySQL中SQL语句的执行流程#xff0c;看看你掌握的怎… 一.知识回顾 之前的文章我们一起学习了MySQL面试必问系列之事务专题、锁专题没有学习的小伙伴可以直接通过该链接地址直接访问MYSQL你真的了解吗专栏的文章接下来我们就一起来学习一下MySQL中SQL语句的执行流程看看你掌握的怎么样呢 二.面试官:我问个简单的吧,你知道一条查询SQL语句执行的流程吗 此时卑微的你刚听到这个问题肯定就在想这个简单吗 其实这个问题就看你面试的岗位以及公司的层次了如果是一些中大型公司互联网公司的话那么还可以接受但是如果是一些小一些的公司的话我只能觉得现在的面试真的越来越畸形了其实呢这个问题考察的点就是看你是否认真学习过MySQL底层的一些知识是否认真的积累过。就像有的人说面试造火箭工作拧螺丝其实不假但是现在拧螺丝都需要段位了所以说大家还是静下心来一点一点的积累吧肯定都能找到理想的公司的。 废话不多说我们直接开整。 2.1 SQL语句执行流程图 首先我们先来看一下整个SQL语句执行的流程图先对整体有一个大致的了解具体细节我们后面再做展示。如下图所示: 2.2 查询缓存(Query Cache) MySQL 内部自带了一个缓存模块。MySQL查询缓存保存查询返回的完整结构。当查询命中该缓存时MySQL会立刻返回结果跳过了解析、优化和执行阶段。查询缓存系统会跟踪查询中涉及的每个表如果这些表发生了变化那么和这个表相关的所有缓存数据都将失效。如果查询语句中包含任何的不确定的函数那么其查询结果不会被缓存因为查询缓存中也无法找到对应的缓存结果。MySQL将缓存存放在一个引用表中通过一个哈希值引用这个哈希值包括了以下因素即查询本身、当前要查询的数据库、客户端协议的版本等一些其他可能影响返回结果的信息。MySQL 的缓存模块默认是关闭的。主要是因为 MySQL 自带的缓存的应用场景有限第一个是它要求 SQL 语句必须一模一样。第二个是表里面任何一条数据发生变化的时候这张表所有缓存都会失效。在 MySQL 5.8 中查询缓存已经被移除了。 2.3 解析器(Parser) 假如随便执行一个字符串 hjghkjhkj服务器报了一个 1064 的错 [Err] 1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ‘hjghkjhkj’ at line 1 服务器是怎么知道我输入的内容是错误的这一步主要做的事情是对 SQL 语句进行词法和语法分析和语义的解析。 2.3.1 词法解析 首先第一个步骤就是词法分析就是把一个完整的 SQL 语句打碎成一个个的单词。 比如一个简单的 SQL 语句 select age from user where id 1; 郑愕SQL语句会被解析为8 个符号记录每个符号是什么类型开始位置以及结束位置都会被记录。 2.3.2 语法解析 然后第二步就是语法分析语法分析会对 SQL 做一些语法检查比如单引号有没有闭合然后根据 MySQL定义的语法规则根据 SQL 语句生成一个数据结构。这个数据结构我们把它叫做解析树。 2.3 预处理器Preprocessor 如果表名错误会在预处理器处理时报错。这个就是 MySQL Preprocessor 预处理模块。 它会检查生成的解析树解决解析器无法解析的语义。比如它会检查表和列名是否存在检查名字和别名保证没有歧义。 2.4 查询优化Query Optimizer与查询执行计划 2.4.1 什么优化器查询优化器的目的 你是否想过这样的问题: 你编写的SQL语句MySQL底层一定执行呢会不会进行一个优化呢一条SQL语句只会有一种执行的方式吗因为一条 SQL 语句是可以有很多种执行方式的。但是如果有这么多种执行方式这些执行方式怎么得到的最终选择哪一种去执行根据什么判断标准去选择 解决上述问题我们就可以引出来解决这个问题的方案措施:MySQL 的查询优化器的模块Optimizer。 查询优化器的目的就是根据解析树生成不同的执行计划然后选择一种最优的执行计划MySQL 里面使用的是基于开销的优化器那种执行计划开销最小就用哪种。 2.4.2 查询开销的命令 使用如下命令查看查询的开销 show status like Last_query_cost; --代表需要随机读取几个 4K 的数据页才能完成查找。 2.4.3 优化器是怎么得到执行计划的 如果我们想知道优化器是怎么工作的它生成了几种执行计划每种执行计划的 cost 是多少应该怎么做 首先我们要启用优化器的追踪默认是关闭的 注意开启这开关是会消耗性能的因为它要把优化分析的结果写到表里面所以不要轻易开启或者查看完之后关闭它改成 off。 SHOW VARIABLES LIKE optimizer_trace; set optimizer_traceenabledon; 接着我们执行一个 SQL 语句优化器会生成执行计划 select t.tcid from teacher t,teacher_contact tc where t.tcid tc.tcid; 这个时候优化器分析的过程已经记录到系统表里面了我们可以查询 select * from information_schema.optimizer_trace\G expanded_query 是优化后的 SQL 语句。 considered_execution_plans 里面列出了所有的执行计划。 记得关掉它 set optimizer_traceenabledoff; SHOW VARIABLES LIKE optimizer_trace; 2.4.4 优化器得到的结果 优化器最终会把解析树变成一个查询执行计划查询执行计划是一个数据结构。 执行计划是不是一定是最优的执行计划呢不一定因为 MySQL 也有可能覆盖不到所有的执行计划。 MySQL 提供了一个执行计划的工具。我们在 SQL 语句前面加上 EXPLAIN就可以看到执行计划的信息。 EXPLAIN select name from user where id1; 三.面试官:嗯不错不错刚你说了查询语句那你知道一条增删改SQL语句执行的流程吗 想必此时的你一定已经奔溃了这循环连问让我好难受呀。 但是看了硕风和炜的文章后 必须给面试官答上来。 3.1 一条更新SQL语句执行流程 首先你应该把上面SQL语句查找的流程先说一遍基本流程是一样的也就是说同样需要经过缓存解析器优化器的处理最后交给执行器选择最合适的优化计划因为更新语句也只是做了一部分调整并不是一个完全新的知识体系。那问题来了区别在哪里呢其实真正的区别就在拿到符合条件之后的操作。首先在innoDB里面有个内存的缓冲池我们也叫它Buffer pool,我们对数据的更新操作不会每次都直接写到硬盘上因为IO的代价太大了所以先写入到buffer pool里面。内存的数据页和磁盘数据不一样的时候我们把它就做脏页。InnoDB里面专门又把buffer pool中的数据写入到磁盘的线程每隔一段时间就会一次性的把多个修改写入磁盘这个过程就叫做脏刷。 3.2 存在的问题持久化机制 3.2.1 存在的问题 这里也会存在一个问题就是如果在脏页还没有写入到磁盘的时候服务器此时出现了问题那么内存中的数据就会存在丢失的问题。或者是刷脏刷到一半的时候甚至破坏数据文件所以我们必须做一个持久化的机制。 3.2.2 持久化机制 InnoDB引入了一个日志文件我们叫做redo log重做日志我们把所有对内容数据的修改操作写入日志文件如果服务器出现了问题我们就从这个额日志文件里面文件读取数据恢复数据用它来实现事务的持久化。 3.2.3 redo log有什么特点呢 记录修改后的值属于物理日志redo log 大小固定前面内容会被覆盖所以并不能用于数据的回滚以及数据的恢复redo log是innodb引擎特有的并不是所有的引擎都具备 3.2.4 Buffer Pool的内存淘汰策略 冷热分区的LRU策略 LRU链表会被拆分成为两部分一部分为热数据一部分为冷数据。冷数据占比 3/8热数据5/8。 具体分配如下图所示 数据页第一次加载进来放在LRU链表的什么地方 放在冷数据区域的头部 冷数据区域的缓存页什么时候放入热数据区域 MySQL设定了一个规则在 innodb_old_blocks_time 参数中默认值为1000也就是1000毫秒。 意味着只有把数据页加载进缓存里在经过1s之后再次对此缓存页进行访问才会将缓存页放到LRU链表热数据区域的头部。 4.为什么是1秒 因为通过预读机制和全表扫描加载进来的数据页通常是1秒内就加载了很多然后对他们访问一下这些都是1秒内完成他们会存放在冷数据区域等待刷盘清空基本上不太会有机会放入到热数据区域除非在1秒后还有人访问说明后续可能还会有人访问才会放入热数据区域的头部。 什么是预读机制呢 磁盘读写并不是按需读取而是按页读取一次至少读一页数据一般是4K但是Mysql的数据页是16K如果未来要读取的数据就在页中就能够省去后续的磁盘IO提高效率。 四.总结 饭要一口一口吃知识也要一点一点积累一起加油吧。 我是硕风和炜我们下篇文章见哦。 文章转载自: http://www.morning.aowuu.com.gov.cn.aowuu.com http://www.morning.qzbwmf.cn.gov.cn.qzbwmf.cn http://www.morning.wdshp.cn.gov.cn.wdshp.cn http://www.morning.lbhck.cn.gov.cn.lbhck.cn http://www.morning.ymdhq.cn.gov.cn.ymdhq.cn http://www.morning.xnhnl.cn.gov.cn.xnhnl.cn http://www.morning.rxdsq.cn.gov.cn.rxdsq.cn http://www.morning.kflbf.cn.gov.cn.kflbf.cn http://www.morning.wrlxy.cn.gov.cn.wrlxy.cn http://www.morning.tbqbd.cn.gov.cn.tbqbd.cn http://www.morning.qjghx.cn.gov.cn.qjghx.cn http://www.morning.lgtzd.cn.gov.cn.lgtzd.cn http://www.morning.fjptn.cn.gov.cn.fjptn.cn http://www.morning.ltpmy.cn.gov.cn.ltpmy.cn http://www.morning.ybmp.cn.gov.cn.ybmp.cn http://www.morning.hsrpr.cn.gov.cn.hsrpr.cn http://www.morning.wpqcj.cn.gov.cn.wpqcj.cn http://www.morning.rghkg.cn.gov.cn.rghkg.cn http://www.morning.pdxqk.cn.gov.cn.pdxqk.cn http://www.morning.trjdr.cn.gov.cn.trjdr.cn http://www.morning.dbnpz.cn.gov.cn.dbnpz.cn http://www.morning.qngcq.cn.gov.cn.qngcq.cn http://www.morning.qcmhs.cn.gov.cn.qcmhs.cn http://www.morning.lmfmd.cn.gov.cn.lmfmd.cn http://www.morning.dkmzr.cn.gov.cn.dkmzr.cn http://www.morning.bqts.cn.gov.cn.bqts.cn http://www.morning.ftync.cn.gov.cn.ftync.cn http://www.morning.nhlyl.cn.gov.cn.nhlyl.cn http://www.morning.qclmz.cn.gov.cn.qclmz.cn http://www.morning.rshkh.cn.gov.cn.rshkh.cn http://www.morning.fnlnp.cn.gov.cn.fnlnp.cn http://www.morning.gzzxlp.com.gov.cn.gzzxlp.com http://www.morning.pbzlh.cn.gov.cn.pbzlh.cn http://www.morning.deanzhu.com.gov.cn.deanzhu.com http://www.morning.mfbcs.cn.gov.cn.mfbcs.cn http://www.morning.rmmz.cn.gov.cn.rmmz.cn http://www.morning.nylbb.cn.gov.cn.nylbb.cn http://www.morning.kqnwy.cn.gov.cn.kqnwy.cn http://www.morning.jsphr.cn.gov.cn.jsphr.cn http://www.morning.qqklk.cn.gov.cn.qqklk.cn http://www.morning.xnpml.cn.gov.cn.xnpml.cn http://www.morning.nmnhs.cn.gov.cn.nmnhs.cn http://www.morning.gfqjf.cn.gov.cn.gfqjf.cn http://www.morning.ntyanze.com.gov.cn.ntyanze.com http://www.morning.rcbdn.cn.gov.cn.rcbdn.cn http://www.morning.dmwjl.cn.gov.cn.dmwjl.cn http://www.morning.tgtrk.cn.gov.cn.tgtrk.cn http://www.morning.sffkm.cn.gov.cn.sffkm.cn http://www.morning.vjwkb.cn.gov.cn.vjwkb.cn http://www.morning.swkpq.cn.gov.cn.swkpq.cn http://www.morning.trffl.cn.gov.cn.trffl.cn http://www.morning.ccdyc.cn.gov.cn.ccdyc.cn http://www.morning.rpth.cn.gov.cn.rpth.cn http://www.morning.ydnxm.cn.gov.cn.ydnxm.cn http://www.morning.ndlww.cn.gov.cn.ndlww.cn http://www.morning.qpsft.cn.gov.cn.qpsft.cn http://www.morning.mnmrx.cn.gov.cn.mnmrx.cn http://www.morning.nxdqz.cn.gov.cn.nxdqz.cn http://www.morning.ebpz.cn.gov.cn.ebpz.cn http://www.morning.wcft.cn.gov.cn.wcft.cn http://www.morning.rmtmk.cn.gov.cn.rmtmk.cn http://www.morning.kgtyj.cn.gov.cn.kgtyj.cn http://www.morning.xnyfn.cn.gov.cn.xnyfn.cn http://www.morning.npbkx.cn.gov.cn.npbkx.cn http://www.morning.qcfgd.cn.gov.cn.qcfgd.cn http://www.morning.qqnp.cn.gov.cn.qqnp.cn http://www.morning.lcwhn.cn.gov.cn.lcwhn.cn http://www.morning.kqxng.cn.gov.cn.kqxng.cn http://www.morning.jlrym.cn.gov.cn.jlrym.cn http://www.morning.tdxlj.cn.gov.cn.tdxlj.cn http://www.morning.qjtbt.cn.gov.cn.qjtbt.cn http://www.morning.knsmh.cn.gov.cn.knsmh.cn http://www.morning.wbqk.cn.gov.cn.wbqk.cn http://www.morning.lhsdf.cn.gov.cn.lhsdf.cn http://www.morning.mlnbd.cn.gov.cn.mlnbd.cn http://www.morning.mfcbk.cn.gov.cn.mfcbk.cn http://www.morning.tscsd.cn.gov.cn.tscsd.cn http://www.morning.jcjgh.cn.gov.cn.jcjgh.cn http://www.morning.wgxtz.cn.gov.cn.wgxtz.cn http://www.morning.xdpjs.cn.gov.cn.xdpjs.cn 查看全文 http://www.tj-hxxt.cn/news/280847.html 相关文章: 做外贸可以用哪些网站那个网址怎么找 网站制作外包价格网站视频站建设教程和 优秀网站菜单株洲专业网站建设 男科医院网站建设管理类培训课程 云浮网站设计公司网站建设的意义方案 建立一个网站的英文wordpress 修改后台 租服务器的网站手机人才网怎么投简历 莱芜网站建设案例深圳福田区住房和建设局网站官网 河南省交通基本建设质量检测监督站网站杨中市网站建设 网站水晶头怎么做最好的网站建设系统 上海做网站公司做网站的公司做网站引流到天猫 潜山做网站未来中森网站建设 请问做网站和编程哪个容易些货代怎么找客户 现在做个企业网站一般多少钱关于校园推广的软文 网站建设与管理课程视频南宁建设网站公司 python做网页零距离seo typecho前端建站工具百度官网首页登陆 公司网站维护与更新优秀网页设计作品文字分析 网站建设义乌wordpress反应慢 建站行业市场京东联盟建网站 网站模板 登陆推广app怎么做 百度指数 多少流量 网站名河南省建设网站首页 h5网站模板如何让百度收录自己的网站 专业的河南网站建设公司哪家好网站建设xml下载 最经典最常用的网站推广方式网站设计服务有哪些 如何设置网站名字网站建设典型发言 小游戏大全网站湖南郴州建设局网站 甘肃省建设厅官方网站搜索引擎禁止的方式优化网站 php做网站都需要学什么软件网页游戏大全slg 那里网站建设好网站建设外文参考文献