My Oracle SQL Tuning Roadmap PART1

560阅读 0评论2022-04-14 dingjun123
分类:Oracle

目录

1.  SQL优化的本质

2.  SQL优化Road Map

2.1 制定SQL优化目标

2.2 检查执行计划

2.3 检查统计信息

2.4 检查高效访问结构

2.5 检查影响优化器的参数

2.6 SQL语句编写问题

2.7 优化器限制导致的执行计划差

3.  SQL优化案例

4.  SQL执行计划获取

4.1 如何获取准确的执行计划

4.2 看懂执行计划执行顺序

 
一SQL优化的本质 

      一般来说,SQL优化是让SQL运行得更快,使SQL更快的方式有很多,比如提高索引的使用效率,或者并行查询。可以看到里面的公式:

执行效率或者一般说的执行时间,是和完成一次SQL所需要访问的资源总量(S)成正比以及单位时间内能够访问的资源量(V)成反比,S越大,效率越低,V越大效率越高。 比如通过并行查询,则可以提升单位时间内访问的资源量。

当然,这仅仅是从执行时间上考虑,SQL优化肯定不仅仅是执行时间降低,应该是资源使用与执行时间降低之间寻求一种平衡,否则,盲目并行,可能提升不了效率,反而让系统资源消耗殆尽。


最终来说,SQL优化的本质就是:1、缩短响应时间;2、提升系统吞吐量;3、提升系统负载能力。要使用多种手段,在提升系统吞吐量和增加系统负载能力,提高单个SQL效率之间寻求一种平衡。就是要尽量减少一条SQL需要访问的资源总量,比如走索引更好,那么就不要使用全表扫描。


执行效率或者一般说的执行时间,是和完成一次SQL所需要访问的资源总量(S)成正比以及单位时间内能够访问的资源量(V)成反比,S越大,效率越低,V越大效率越高。 比如通过并行查询,则可以提升单位时间内访问的资源量。

当然,这仅仅是从执行时间上考虑,SQL优化肯定不仅仅是执行时间降低,应该是资源使用与执行时间降低之间寻求一种平衡,否则,盲目并行,可能提升不了效率,反而让系统资源消耗殆尽。


最终来说,SQL优化的本质就是:1、缩短响应时间;2、提升系统吞吐量;3、提升系统负载能力。要使用多种手段,在提升系统吞吐量和增加系统负载能力,提高单个SQL效率之间寻求一种平衡。就是要尽量减少一条SQL需要访问的资源总量,比如走索引更好,那么就不要使用全表扫描。


上一篇:深入了解SQL性能杀手FILTER操作_PART5
下一篇:My Oracle SQL Tuning Roadmap PART2