SQL优化

SQL优化

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

步骤

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

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

  • 明确的优化目标

  • 慢查询的开启与捕获

  • explain+慢SQL分析

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

  • 进行MySQL的参数调整优化

优化原则

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

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

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

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

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

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

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

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

本文由mdnice多平台发布

相关推荐
哈__1 小时前
MongoDB 平替新方案:金仓多模数据库驱动电子证照国产化落地
数据库·1024程序员节
微学AI2 小时前
国产数据库替代MongoDB的技术实践过程:金仓多模数据库在电子证照系统中的深度应用
数据库·人工智能·1024程序员节
TDengine (老段)2 小时前
TDengine 数据函数 ROUND 用户手册
java·大数据·数据库·物联网·时序数据库·tdengine·1024程序员节
TDengine (老段)2 小时前
TDengine 数学函数 RAND 用户手册
java·大数据·数据库·物联网·时序数据库·tdengine·涛思数据
野犬寒鸦3 小时前
从零起步学习MySQL || 第十章:深入了解B+树及B+树的性能优势(结合底层数据结构与数据库设计深度解析)
java·数据库·后端·mysql·1024程序员节
GZ_TOGOGO3 小时前
Oracle OCP考试报名常见问题详解
数据库·oracle·ocp认证
睡不醒的猪儿3 小时前
nginx日志同步阿里云datahub后写入数据库
数据库·nginx·阿里云
xie_zhr3 小时前
【PB案例学习笔记】-46在数据窗口中编辑数据
数据库·his·1024程序员节·干货分享·pb·powerbuilder
小小的木头人3 小时前
Redis 集群安装指南
数据库·redis
星空的资源小屋3 小时前
Antares SQL,一款跨平台开源 SQL 客户端
数据库·人工智能·pdf·开源·电脑·excel·1024程序员节