当前位置:   article > 正文

MySQL数据库基础知识7,查询的执行过程_mysql查询执行过程

mysql查询执行过程

一、拆分查询

将大查询拆分成小查询,每个查询功能完全一样,只是一小部分,每次只返回一小部分查询结果。

比如在删除旧数据的时候,如果用一个大的语句一次性删的话,则可能需要一次性锁住很多数据、占满整个事务日志、耗尽系统资源、阻塞其它查询任务。如果将一个大的删除语句拆分成若干个较小的删除语句,可以提升MySQL的性能。一次删除一万行数据一般来说是一个比较高效并且对服务器影响最小的做法。

二、分解关联查询

分解关联查询的优势

  1. 让缓存更高效,如果某个表改变了,就无法使用查询缓存了,而拆分后,如果其它表没变化,那么基于这些表的查询就可以使用缓存结果了;
  2. 将查询分解后,执行单表查询时可以减少锁的竞争;
  3. 在应用层做关联,可以更容易对数据进行拆分,更容易做到高性能和高扩展;
  4. 查询本身的效率也可能会提升;
  5. 可以减少冗余记录的查询

三、查询的执行过程

  1. 客户端发送一条查询语句到服务器
  2. 服务器先查询缓存,如果命中缓存,则立即返回存储在缓存中的数据;
  3. 未命中缓存后,MySQL通过关键字将SQL语句进行解析,并生成一颗对应的解析树,MySQL解析器将使用MySQL语法进行验证和解析。例如,验证是否使用了错误的关键字,或者关键字的使用是否正确;
  4. 预处理是根据一些MySQL规则检查解析树是否合理,比如检查表和列是否存在,还会解析名字和别名,然后预处理器会验证权限;
  5. 根据执行计划查询执行引擎,调用API
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/在线问答5/article/detail/835492
推荐阅读
相关标签
  

闽ICP备14008679号