SQL优化

SQL优化

SQL的优化并不是一开始就进行优化的,而是需要先进行观察的,所以SQL优化的步骤应该是这样的

步骤

  • 定位优化对象的性能瓶颈

    首先要判断出这个Query的瓶颈到底是IO还是CPU,可以使用profiling功能来找到Query的瓶颈

  • 明确的优化目标

  • 慢查询的开启与捕获

  • explain+慢SQL分析

  • show profile查询SQL在MySQL服务器里的执行细节和生命周期情况

  • 进行MySQL的参数调整优化

优化原则

  • 减少数据扫描(减少磁盘访问)

    • 尽量在查询中加入一些可以提前过滤数据的条件,比如按照时间过滤数据等,可以减少数据的扫描量,对查询更友好;
    • 在扫描大表数据时是否可以命中索引,减少回表代价,避免全表扫描。
  • 返回更少数据(减少网络传输或磁盘访问)

    • 只取出自己需要的Columns。返回的数据需要通过网络数据包传回客户端,如果取出的Column越多,需要传输的数据量自然会越大
  • 减少交互次数(减少网络传输)

    • 将数据存放在更快的地方
    • 某条查询涉及到大表,无法进一步优化,如果返回的数据量不大且变化频率不高但访问频率很高,此时应该考虑将返回的数据放在应用端的缓存当中或者 Redis 这样的缓存当中,以提高存取速度。
  • 永远使用小结果集驱动大的结果集

    驱动结果集越大,所需要循环的次数就越多,那么被驱动表的访问次数自然也就越多

  • 仅仅使用最有效地过滤条件

  • 尽可能避免复杂的join和子查询

zhhll.icu/2021/数据库/关系...

本文由mdnice多平台发布

相关推荐
TechWayfarer几秒前
网络安全视角:利用IP定位API接口识别机房与基站流量(合规风控篇)
开发语言·网络·数据库·python·安全·网络安全
dinglu1030DL1 分钟前
Less如何构建CSS样式库_通过继承机制优化组件化开发
jvm·数据库·python
chushiyunen4 分钟前
postgresql安装timescaledb替代influxdb功能、查看已安装的插件
数据库·postgresql
duke8692672148 分钟前
C#怎么获取U盘的插拔事件_C#如何重写WndProc捕获消息【进阶】
jvm·数据库·python
数据库小学妹11 分钟前
CDC实时数据同步:让数据库变更秒级流向大数据平台!
大数据·数据库·mysql·kafka·dba
m0_6908258213 分钟前
如何高效实现多用户通知系统而不造成数据库冗余
jvm·数据库·python
XZ-07000116 分钟前
MySQL-视图
数据库·mysql
2301_8125396717 分钟前
golang如何使用Fiber高性能框架_golang Fiber框架入门教程
jvm·数据库·python
2401_8800714020 分钟前
html标签如何提升可访问性_aria-label与title区别【指南】
jvm·数据库·python
2401_8504916522 分钟前
如何管理多个监听器_listener.ora中非默认端口配置实战
jvm·数据库·python