当前位置 : 首页 > 徐州软件行业资讯 > 一个不懂业务的DBA不是好的DBA

一个不懂业务的DBA不是好的DBA

作者:徐州软件公司  文章来源:徐州软件公司   阅读次数:496 次
2017-05-25

此文章是徐州软件公司整理的技术资料,由徐州软件公司总务部发布,邮箱:zongwu@xuzhousoft.com

江苏徐软信息科技有限公司江苏徐软信息科技有限公司

徐州软件公司徐州徐软信息科技有限公司认为懂业务,懂系统逻辑,你才能做一个更好的DBA。本文来自云和恩墨大讲堂朋友的投稿。

在数据库巡检中发现一个MES生产信息数据库中一个存储过程中一条SQL单次逻辑读为2100,且执行很频繁,占数据库整体逻辑读70%。SQL本意是查询特定条码在C_LABEL_DESC_T条码基本信息表中有无维护,查询结果只为1或0。

SELECTCOUNT( * )

INTO count_ll3

FROM C_LABEL_DESC_T

WHERE     label_type =’CARTON’

ANDLENGTH(START_BARCODE)=LENGTH(DATA)

AND START_BARCODE <=DATA

AND END_BARCODE>=DATA

ANDROWNUM<2

AND model_name LIKE’%-W’;

SQL执行计划的ACCESS Predicate使用了 END_BARCODE>=:DATA条件,END_BARCODE为VARCHAR2类型,对其进行>=范围查询效率不佳才产生了单次2100的逻辑读。

先看一下数据分布,LABEL_TYPE值为’CARTON’的记录占绝大多数,没法对LABEL_TYPE字段加索引来解决问题。CBO这条路已经走不通,只有从应用层面下手优化。

SQL>  SELECT label_type, COUNT ( * )

FROM C_LABEL_DESC_T

GROUP BY label_type

ORDER BY 2 DESC;

LABEL_TYPE   COUNT(*)

—————– ———-

CARTON            16489

SN                      1161

1、可否降低执行频率?

如果可以降低存储过程执行频率1个数量级,那就是最简单的解决问题办法。

开发人员回应此条SQL在生产线的包装工站被调用,生产线上扫描每个主板SN或箱号SN时都会调用,DATA变量值即为传入的SN,存储过程执行频率无法降低。

2、第一次改写

典型生产线OLTP系统中查询历史信息概率很低,代入存储过程的的SN一般情况下都是最近几天才维护进条码规则表中。C_LABEL_DESC_T表中的WORK_DATE字段与开发人员确认就是条码规则条目的维护时间。

分析一下WORK_DATE值的数据分布:

SQL> SELECTTRUNC (  (SELECT COUNT ( * )

FROM C_LABEL_DESC_T

WHEREWORK_DATE > SYSDATE – 3)

/ (SELECT COUNT (* ) FROM C_LABEL_DESC_T)

* 100, 1)

percent

FROM DUAL;

PERCENT

———-

8.5

可以看出此表中绝大部分都是历史数据,最近3天维护的只占8.5%。

估计代入存储过程的SN为最近3天维护进条码规则表的概率有95%,不是最近3天维护的概率只有约5%。对DATE类型字段查询3天内数据就可利用到WORK_DATE字段索引了,应比对VARCHAR2字段进行范围查询效率更高。

依据此思路进行第一次改写存储过程如下:

/*判断此条码是否维护进最近三天维护的条码规则内*/

SELECTCOUNT( * )

INTO count_ll3

FROM C_LABEL_DESC_T

WHERE     label_type =’CARTON’

ANDLENGTH(START_BARCODE)=LENGTH(data)

AND START_BARCODE <=DATA

AND END_BARCODe >=DATA

ANDROWNUM<2

AND model_name LIKE’%-W’

AND work_date >=SYSDATE-3;

/*如最近三天维护的条码规则中未查到,再查询3天以前数据*/

IF count_ll3 =0

THEN

SELECTCOUNT( * )

INTO count_ll3

FROM C_LABEL_DESC_T

WHERE     label_type =’CARTON’

AND LENGTH(START_BARCODE)=LENGTH(data)

AND START_BARCODE <=DATA

AND END_BARCODe >=DATA

ANDROWNUM<2

AND model_name LIKE’%-W’

AND work_date <SYSDATE-3;

ENDIF;

改写后再进行观察DB整体逻辑读有降低,但下降比例只有个位数,这个存储过程的逻辑读在AWR报告中仍占Top 1,问题到底出在那里?

与开发人员沟通得知DATA变量的值虽然有可能是主板SN或箱号SN,但为主板SN的概率比箱号SN大的多(一箱会放上百片主板)。如果DATA变量值是主板SN,必全部走完以上PL/SQL块中所有逻辑,再得出count_ll3为0,我们预期中的Performance Improvement就落空了。

3、第二次改写

主板SN全部保存在R_WIP_TRACKING表中的SERIAL_NUMBER字段,并且为主键,如果我们先判断DATA变量值是否为主板SN,并对count_ll3赋值,后面的判断逻辑就不需执行。

依此思路再次进行改写:

/*先判断DATA变量值是否为主板SN*/

SELECTCOUNT( * )

INTO count_ll3

FROM R_WIP_TRACKING

WHERE SHIPPING_SN =DATA;

/*如果传入值为主板SN,那即可确认对应的Label_Type为SN,可直接跳过IF块*/

IF count_ll3 =0

THEN

/*再判断此条码是否维护进最近三天维护的条码规则内*/

SELECTCOUNT( * )

INTO count_ll3

FROM C_LABEL_DESC_T

WHERE     label_type =’CARTON’

ANDLENGTH(START_BARCODE)=LENGTH(data)

AND START_BARCODE <=DATA

AND END_BARCODe >=DATA

ANDROWNUM<2

AND model_name LIKE’%-W’

AND work_date >=SYSDATE-3;

/*如最近三天维护的条码规则中未查到,再查询3天以前数据*/

IF count_ll3 =0

THEN

SELECTCOUNT( * )

INTO count_ll3

FROM C_LABEL_DESC_T

WHERE     label_type =’CARTON’

ANDLENGTH(START_BARCODE)=LENGTH(data)

AND START_BARCODE <=DATA

AND END_BARCODe >=DATA

ANDROWNUM<2

AND model_name LIKE’%-W’

AND work_date <SYSDATE-3;

ENDIF;

ENDIF;

改写后,在GridControl与AWR报告中此存储过程的执行信息彻底不见,数据库整体逻辑读降低70%,问题得到圆满解决。

SQL优化的过程也是DBA对系统逻辑与业务流程的熟悉过程,掌握前两者优化再加上一点耐心方可游刃有余。

The  End.

江苏徐软信息科技有限公司(简称徐州软件公司)是徐州软件公司中成立时间最长、技术能力最强、经济实力最雄厚的徐州软件开发公司之一,专业的徐州软件开发团队,从事徐州软件开发10年,一直保持着徐州软件开发行业排头兵的地位。徐州软件公司徐州软件开发行业内的众多徐州软件开发公司保持着良好的合作关系,是徐州软件开发行业的领航者之一。徐州软件公司立足徐州软件开发市场,主攻徐州软件开发徐州APP开发徐州软件公司徐州ERP软件开发徐州OA软件开发徐州CRM软件开发等领域拥有大量经典案例。更多信息请访问徐州软件公司官方网站:

徐软com:http://www.xuzhousoft.com  徐软cn:http://www.xuzhousoft.com.cn
徐软app:http://app.xuzhousoft.com  淮北徐软:http://huaibei.xuzhousoft.com.cn
济宁徐软:http://jining.xuzhousoft.com.cn  亳州徐软:http://bozhou.xuzhousoft.com.cn
菏泽徐软:http://heze.xuzhousoft.com.cn  宿州徐软:http://suzhou.xuzhousoft.com.cn
枣庄徐软:http://zaozhuang.xuzhousoft.com.cn  宿迁徐软:http://suqian.xuzhousoft.com.cn
商丘徐软:http://shangqiu.xuzhousoft.com.cn  连云港徐软:http://lianyungang.xuzhousoft.com.cn
莱芜徐软:http://laiwu.xuzhousoft.com.cn  泰安徐软:http://taian.xuzhousoft.com.cn
日照徐软:http://rizhao.xuzhousoft.com.cn  开封徐软:http://kaifeng.xuzhousoft.com.cn
周口徐软:http://zhoukou.xuzhousoft.com.cn  盐城徐软:http://yancheng.xuzhousoft.com.cn
淮安徐软:http://huaian.xuzhousoft.com.cn  阜阳徐软:http://fuyang.xuzhousoft.com.cn
蚌埠徐软:http://bengbu.xuzhousoft.com.cn  临沂徐软:http://linyi.xuzhousoft.com.cn
邳州徐软:http://pizhou.xuzhousoft.com.cn  新沂徐软:http://xinyi.xuzhousoft.com.cn
沛县徐软:http://peixian.xuzhousoft.com.cn  睢宁徐软:http://suining.xuzhousoft.com.cn
丰县徐软:http://fengxian.xuzhousoft.com.cn  萧县徐软:http://xiaoxian.xuzhousoft.com.cn
砀山徐软:http://dangshan.xuzhousoft.com.cn  微山徐软:http://weishan.xuzhousoft.com.cn
永城徐软:http://yongcheng.xuzhousoft.com.cn  网络营销:http://www.f168yingxiao.com
徐州系统集成公司:http://www.0516app.com

关键字标签:徐州软件公司 徐州软件开发公司 徐州APP软件开发公司 徐州ERP软件开发公司 徐州CRM软件开发公司 徐州OA软件开发公司

下载DOC版 下载PDF版

* 以上内容由 徐州软件公司 整理


关于我们

    江苏徐软信息科技有限公司(简称徐州软件)位于国家大学科技园内,成立于2005年,注册资金1000万元,是徐州地区最具实力的集软件开发、电子商务技术服务、门户网站建设、系统集成、网络工程为一体的高科技IT技术公司之一。

技术支持

  • 售后服务电话:0516-83003411
  • 售后服务QQ:412110939
  • 售后服务邮箱:
    service@xuzhousoft.com
  • 售后投诉电话:18795428064
徐州软件公司
    扫描微信二维码即可获得
    免费信息化咨询服务

Copyright© 2005 江苏徐软信息科技有限公司 All Rights Reserved.
苏公网安备 32030302000144号  苏ICP备11059116号-5

地址:江苏省徐州市云龙区和平路57号江苏师范大学科技园4F  徐州软件公司
电话:0516-83737996 邮箱:sales@xuzhousoft.com

江苏徐软信息科技有限公司地图
江苏徐软信息科技有限公司地图
点这里关闭本窗口
×