首页 存档 技术 查看内容

如何保持Oracle数据库SQL性能的稳定性

2018-3-30 13:00 |来自: 互联网 359 0

摘要: 来源|Oracle(ID:OraNews) 作者|盖国强 已授权,转载请联系授权平台 使用Oracle数据库的应用系统,有时出现SQL性能突然变差,特别是对于OLTP类型系统执行频繁的核心SQL,如果出现性能问题,通常会影响整个数据 ...


来源|Oracle(ID:OraNews)

作者|盖国强

已授权,转载请联系授权平台

使用Oracle数据库的应用系统,有时出现SQL性能突然变差,特别是对于OLTP类型系统执行频繁的核心SQL,如果出现性能问题,通常会影响整个数据库的性能,进而影响整个系统的正常运行。这是常常遇到的问题,也是一些DBA的挑战。


SQL性能变差原因分析



SQL的性能变差,通常是在SQL语句重新进行了解析,解析时使用了错误的执行计划出现的。


下列情况是SQL会重新解析的原因:

  1. SQL语句没有使用绑定变量,这样SQL每次执行都要解析。

  2. SQL长时间没有执行,被刷出SHARED POOL,再次执行时需要重新解析。

  3. 在SQL引用的对象(表、视图等)上执行了DDL操作,甚至是结构发生了变化,比如建了一个索引。

  4. 对SQL引用的对象进行了权限更改。

  5. 重新分析(收集统计信息)了SQL引用的表和索引,或者表和索引统计信息被删除。

  6. 修改了与性能相关的部分参数。

  7. 刷新了共享池。

  8. 当然重启数据库也会使所有SQL全部重新解析。


SQL重新解析后,跟以前相比,性能突然变差,通常是下列原因:

1. 表和索引的优化统计信息被删除,或者重新收集后统计信息不准确。重新收集统计信息通常是由于收集策略(方法)不正确引起。比如对分区表使用analyze命令而不是用dbms_stats包、收集统计信息时采样比例过小等等。Oracle优化器严重依赖于统计信息,如果统计信息有问题,则很容易导致SQL不能使用正确的执行计划。


2. SQL绑定变量窥探(bind peeking),同时绑定变量对应的列上有直方图;或者绑定变量的值变化范围过大、分区数据分布极不均匀:


1) 绑定变量的列上有直方图:

假如表orders存储所有的订单,state列有3种不同的值:0表示未处理,1表示处理成功完成,2表示处理失败。State列上有一个索引,表中绝大部分数据的state列为1,0和2占少数。有下面的SQL:

select * from orders where state=:b1


这里:b1是变量,在大多数情况下这个值为0,则应该使用索引,但是如果SQL被重新解析,而第一次执行时应用传给变量b1值为1,则不会使用索引,采用全表扫描的方式来访问表。对于绑定变量的SQL,只在第一次执行时才会进行绑定变量窥探,并以此确定执行计划,该SQL后续执行时全部按这个执行计划。这样在后续执行时,b1变量传入的值为0的时候,仍然是第一次执行时产生的执行计划,即使用的是全表扫描,这样会导致性能很差。


2) 绑定变量的值变化范围过大
同样假如orders表有一列created_date表示一笔订单的下单时间,orders表里面存储了最近1年的数据,有如下的SQL:

select * from orders where created_date

声明:文章版权归原作者所有 部分文章转自互联网 如有侵权请联系 [邮箱地址] 删除

路过

雷人

握手

鲜花

鸡蛋

相关分类

返回顶部