Oracle--SQL程序优化案例一
下面是存储过程的一部分程序:
PROCEDURE SAP_MAN_ROUTING_SO (CITEM_ID VARCHAR2,
CSITE_ID VARCHAR2,
CTYPE VARCHAR2)
IS
V_ROUTING VARCHAR2 (40);
BEGIN
IF (CITEM_ID NOT LIKE '%C%')
THEN
SELECT NVL (TRIM (RR.ROUTING_ID), '')
INTO V_ROUTING
FROM (SELECT MAPL.PLNNR || '_' || MAPL.WERKS ROUTING_ID
FROM SAP_MAPL_QMCUSTOMER MAPL
WHERE MAPL.MATNR = CITEM_ID
AND MAPL.WERKS = CSITE_ID
AND EXISTS
(SELECT NULL
FROM SAP_MAPL_QMCUSTOMER
WHERE SAP_MAPL_QMCUSTOMER.MATNR =
CITEM_ID
AND SAP_MAPL_QMCUSTOMER.WERKS =
CSITE_ID)) RR;
ELSIF (CITEM_ID LIKE '%C%')
THEN
SELECT NVL (TRIM (RR.ROUTING_ID), '')
INTO V_ROUTING
FROM (SELECT MAX (MAPL.PLNNR) ROUTING_ID
FROM SAP_MAPL_QMCUSTOMER MAPL
WHERE MAPL.MATNR = CITEM_ID AND MAPL.WERKS = CSITE_ID) RR;
END IF;
从代码上来看,改程序似乎没有什么缺陷,执行也相当顺畅,但有一天突然一直报
ORA-01403: 未找到任何数据ORA-06512: 在 "STG.SAP_SO_BOM_PROC", line 428
ORA-06512: 在 "STG.SAP_SO_BOM_PROC", line 1097
通过分析发现缺少对结果集行数做一个判断,如果返回的是0行数据,那就是没有值,没有值就会报错,
所以以下是对该程序进行判断:
PROCEDURE SAP_MAN_ROUTING_SO (CITEM_ID VARCHAR2,
CSITE_ID VARCHAR2,
CTYPE VARCHAR2)
IS
V_ROUTING VARCHAR2 (40);
qty number;
BEGIN
select count(*) into qty
FROM (SELECT MAPL.PLNNR || '_' || MAPL.WERKS ROUTING_ID
FROM SAP_MAPL_QMCUSTOMER MAPL
WHERE MAPL.MATNR = CITEM_ID
AND MAPL.WERKS = CSITE_ID
AND EXISTS
(SELECT NULL
FROM SAP_MAPL_QMCUSTOMER
WHERE SAP_MAPL_QMCUSTOMER.MATNR =
CITEM_ID
AND SAP_MAPL_QMCUSTOMER.WERKS =
CSITE_ID)) RR;
IF qty>0 then
IF (CITEM_ID NOT LIKE '%C%')
THEN
SELECT NVL (TRIM (RR.ROUTING_ID), '')
INTO V_ROUTING
FROM (SELECT MAPL.PLNNR || '_' || MAPL.WERKS ROUTING_ID
FROM SAP_MAPL_QMCUSTOMER MAPL
WHERE MAPL.MATNR = CITEM_ID
AND MAPL.WERKS = CSITE_ID
AND EXISTS
(SELECT NULL
FROM SAP_MAPL_QMCUSTOMER
WHERE SAP_MAPL_QMCUSTOMER.MATNR =
CITEM_ID
AND SAP_MAPL_QMCUSTOMER.WERKS =
CSITE_ID)) RR;
ELSIF (CITEM_ID LIKE '%C%')
THEN
SELECT NVL (TRIM (RR.ROUTING_ID), '')
INTO V_ROUTING
FROM (SELECT MAX (MAPL.PLNNR) ROUTING_ID
FROM SAP_MAPL_QMCUSTOMER MAPL
WHERE MAPL.MATNR = CITEM_ID AND MAPL.WERKS = CSITE_ID) RR;
END IF;
ELSE
--程序漏洞,没有考虑返回值为0行的结果,现加判断参数qty作为返回行数的总数,大于1将执行原先的程序,否则直接赋空值 add by zhangguipeng20170216
V_ROUTING:='';
END IF;
Oracle--SQL程序优化案例一的更多相关文章
- Oracle SQL性能优化技巧大总结
http://wenku.baidu.com/link?url=liS0_3fAyX2uXF5MAEQxMOj3YIY4UCcQM4gPfPzHfFcHBXuJTE8rANrwu6GXwdzbmvdV ...
- Oracle SQL 性能优化技巧
Select语句完整的执行顺序: SQL Select语句完整的执行顺序: 1. from子句组装来自不同数据源的数据: 2.where子句基于指定的条件对记录行进行筛选: 3.group by子句将 ...
- 利用 Oracle EM 企业管理器 进行oracle SQL的优化(自动生成索引)
利用 Oracle EM 企业管理器 进行oracle SQL的优化(自动生成索引) ##应用情景 项目中有大量的SQL,尤其是涉及到统计报表时,表关联比较多,当初开发建表时也没搞好索引关联的,上线后 ...
- ORACLE SQL性能优化(全)
ORACLE SQL性能优化(全) http://wenku.baidu.com/view/b2aaba3887c24028915fc337.html
- SQL性能优化案例分析
这段时间做一个SQL性能优化的案例分析, 整理了一下过往的案例,发现一个比较有意思的,拿出来给大家分享. 这个项目是我在项目开展2期的时候才加入的, 之前一期是个金融内部信息门户, 里面有个功能是收集 ...
- Oracle SQL语句优化34条
非常好用的SQL语句优化34条 1)选择最有效率的表名顺序(只在基于规则的优化器中有效): ORACLE 的解析器按照从右到左的顺序处理FROM子句中的表名,FROM子句中写在最后的表(基础表 dri ...
- Oracle SQL的优化
SQL的优化应该从5个方面进行调整:1.去掉不必要的大型表的全表扫描2.缓存小型表的全表扫描3.检验优化索引的使用4.检验优化的连接技术5.尽可能减少执行计划的Cost SQL语句:是对数据库(数据) ...
- Oracle SQL性能优化系列
1. 选用适合的ORACLE优化器 ORACLE的优化器共有3种: a. RULE (基于规则) b. COST (基于成本) c. CHOOSE (选择性) 设置缺省的优化器,可以通过对init.o ...
- ORACLE SQL性能优化汇总
ORACLE SQL语句共享 Oracle SQL语句具备共享特性,为了不让ORACLE数据库重复解析相同的简单单表SQL语句,ORACLE在SGA系统共享区域内SBP共享池内存放的SQL语句将被所有 ...
- Oracle-SQL程序优化案例二
有时候写得不规范的SQL语句真的是占用很多时间 以下是我在工作中发现的规律,如果字段过多的使用函数,尽量不要将这些字段串联在一起做匹配或查询条件,比如红色注释部分,在执行红色部分的时候 这个SQL程序 ...
随机推荐
- 四、Zabbix-zabbix agent部署
1.添加zabbix安装源 rpm -i http://repo.zabbix.com/zabbix/3.4/rhel/7/x86_64/zabbix-release-3.4-2.el7.noarch ...
- Redis进阶:Redis的主从复制机制
Redis进阶:Redis的主从复制机制 主从复制机制介绍 单机版的Redis存在性能瓶颈,Redis通过提高主从复制实现读写分离,提高了了Redis的可用性,另一方便也能实现数据在多个Redis直接 ...
- 2019上海网络赛B题(差分 + 离散化 or 差分 + 思维)
这题.....队里都没怎么训练差分,导致败北...写了一堆线段树嘤嘤嘤,到最后也是超时,比赛结束后看到了差分的思想于是就去学了一手. 其实了解差分思想的一眼就能看出来是差分了.但是如果对n差分的话很明 ...
- 思维体操: HDU1049Climbing Worm
Climbing Worm Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) To ...
- kotlin学习(8)泛型
泛型的声明 与Java不同的是,Kotlin要求类型实参要么被显示的说明,要么能被编译器推导出来.因为Java在1.5版本才引入泛型,所以为了兼容过去的版本,可以不直接声明List类型的变量,而不说明 ...
- Distributed Deep Learning
安利一下刘铁岩老师的<分布式机器学习>这本书 以及一个大神的blog: https://zhuanlan.zhihu.com/p/29032307 https://zhuanlan.zhi ...
- javascript百度地图使用(根据地名定位、根据经纬度定位)
需要购买阿里云产品和服务的,点击此链接领取优惠券红包,优惠购买哦,领取后一个月内有效: https://promotion.aliyun.com/ntms/yunparter/invite.html? ...
- Django文档——Model中的ForeignKey,ManyToManyField与OneToOneField 关联关系字段 (Relationship fields)
ForeignKey,ManyToManyField与OneToOneField分别在Model中定义多对一,多对多,一对一关系. 例如,一本书由一家出版社出版,一家出版社可以出版很多书.一本书由多个 ...
- 在java中读取文件中的内容
package shi; import java.io.*; public class wenjianIO { public static void main(String agrs[]){ File ...
- IIC通信协议详解
IIC通信详解 IIC概述 IIC:两线式串行总线,它是由数据线SDA和时钟线SCL构成的串行总线,可发送和接收数据. 在CPU与被控IC之间.IC与IC之间进行双向传送,高速IIC总线一般可达400 ...