Delphi 程序错误写法造成Oracle数据库负载异常

作者介绍

张洪涛 富士康 DBA

注意:本文涉及的问题在9i的环境中测试的,经验证,同样适用于11g.

在用Toad的SGA Trace工具监控我们的Oracle 9.2.0.8 Patch 31古董数据库时发现一条奇怪的SQL,它占到数据库整体逻辑读50%以上,SQL如下:

这条SQL单次执行逻辑读不到900,但执行非常频繁,它本意想查询HRM.ORGANIZATION表的表与索引信息。

程序员应该不会特意写这种SQL,那它到底来自哪里?

通过MODEL_NAME,找到SQL对应的Session,并做10046 Trace分析这条SQL与

SELECT departmentname FROM hrm.organization WHERE departmentid=:1交替执行。DB层面已经很难再有什么有价值线索,只有请开发提供源码分析。

这个程序使用Delphi7开发,很快开发将源码发来,代码如下:

分析Delphi程序在执行以下语句时调用了异常SQL。

ADOQuery2.SQL.Add(str_4);

ADOQuery2.Open;

ADOQuery2.First;

程序员正确使用了Delphi ADOQuery控件添加了SQL文本,并调用Open方法执行SQL,但为何要再调用First方法?

ADOQuery的First方法本意为定位到结果集的第一条记录。因为departmentid为主键,SELECT必返回一条记录,此步应为多余。请开发人员屏蔽掉ADOQuery2.First;再上线新版程序观察。

第二天这条诡异SQL仍被监控到,看样子屏蔽掉First方法调用并没有找到Root Cause,需要继续研究源码。

仔细分析此段程式,ADOQuery2调用Select语句时并没有使用绑定变量,是否是因为SQL硬解析造成异常SQL调用?

依此思路再将程序改写成以下使用绑定变量形式,并请程序员再次编译程序并上线。

第三天这条诡异SQL又被监控到,到底是哪里还有问题,还是解决问题的思路错了?再回到前一天改过的源码......

文本改为绑定变量没有错,是否Delphi ADOQuery控件执行Add方法时这条奇怪的SQL被调用?依据这个思路,再修改第三版程序,将ADOQuery 的Add方法调用放到While循环外,并请程序员重新编译上线。

现在在While循环外定义SQL,在While循环内给变量赋值并执行SQL。

继续监控发现这条诡异SQL终于消失了。确认Delphi ADOQuery调用Add方法时调用这条问题SQL获得对应表与索引信息。将Add方法移到While 循环外就彻底消除了循环内对问题SQL的调用。这也是Delphi ADOQuery控件在循环内执行SQL的正确方法。

Remark:

因为我们还有Informix 7 史前数据库,公司Policy规定不可用ODBC访问接口直接访问它,且Oracle 11.2 Gateway又不支持对Informix 7的访问,所以只有保留Oracle 9.2.0.8以利用其异构服务访问Informix 7。

原文发布于微信公众号 - 数据和云(OraNews)

原文发表时间:2017-09-21

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏简书专栏

Pyechart入门

pyecharts是一个用于生成echarts图表的类库。echarts是百度开源的一个数据可视化库,用echarts生成的图可视化效果非常棒。使用pyecha...

2523
来自专栏LuckQI

学习Java基础知识,打通面试关~十二乐观锁与悲观锁

952
来自专栏牛客网

蚂蚁金服暑期实习生一面总结

1122
来自专栏九彩拼盘的叨叨叨

彭小六私密日更群日更活动目录生成代码

1284
来自专栏蓝天

Linux的load average的含义

下面文章中的      “  数据是每隔5秒钟检查一次活跃的进程数,然后根据这个数值算出来的。如果这个数除以CPU的数目,结果高于5的时候就表明系统在超负荷运转...

844
来自专栏一“技”之长

iOS数据持久化之二——归档与设计可存储化的数据模型基类

        在上一篇博客中,我们介绍了用plist文件进行数据持久化的方法。虽然简单易用,但随着开发的深入,你会发现,这种方式还是有很大的局限性。试想,如果...

553
来自专栏PPV课数据科学社区

【学习】七天搞定SAS(四):数据输出

弄清楚了基本的PROC之后,开始研究SAS的输出...毕竟有了数据处理的结果之后,还要有一个比较舒服的输出格式才可以嘛。 SAS的结果发送系统:ODS SAS里...

3108
来自专栏SAP最佳业务实践

SAP最佳业务实践:返工处理(库存制造物料)(151)-2生产订单

image.png CO01创建返工生产订单 在此活动中,制造工人可以从库存中返工制造的物料。 角色生产计划员 后勤®生产®车间现场控制®订单®创建®含物料 1...

2738
来自专栏开发 & 算法杂谈

Django-Database 之 Many-To-Many关系

这里对Many-To-Many即多对多的映射关系以详细事例来分析Django中Database操作多对多映射关系的一些基本用法和注意事项

752
来自专栏SAP最佳业务实践

SAP最佳业务实践:MM–有JIT交货计划的采购(230)-3收货&开票

4.5 MIGO收货 收货是指实际货物和物料的入库过程。收货通常来自于外部供应商或内部生产部门。所有收货都会增加库存。 此步骤仅用于物料H20,H21,看板物料...

4026

扫码关注云+社区