甲骨文存储过程的关键字使用

  

一、问题描述:

写了一个存储过程(只取了半截,能说明命题即可)

凹坠俏拇娲⒐痰墓丶质褂谩? CREATE 或是REPLACE    PROCEDURE “MONTH_RPT_CENTER_STU_DATA_PROC", (centerIds  VARCHAR2拷贝)   AS  mlockdate 日期;   开始/*   创建人:fengcl   创建时间:2018.1.23   更新人:   更新时间:   参数:中心编号(字符串类型)   功能:调用时,先从中间表删除指定中心的数据,再重新查询插入指定中心的数据到中间表   */袢≡卤ㄋㄈ掌?   select  trunc (sysdate & # 39; mm # 39;) + to_number(,名称),into  mlockdate    得到mdm_dic_option  where 代码=& # 39;monthReportDate& # 39;,以及dic_code=& # 39; system_set_001& # 39;;      if  mlockdate< trunc (sysdate),, then    得到rpt_month_stu_data 获delete ;   where  RPT_DATE>=add_months (trunc (sysdate & # 39; mm # 39;), 1),   ,,,以及RPT_DATE

在调用这个存储过程的时候,如果参数centerIds只有一个数字,例如:1可以正常执行,但是如果有多个数字的话,例如:1,2,3,4,5就回报如下错误,

过程执行失败

ora - 01722:无效数字

ora - 06512:在“CRM3TEST.MONTH_RPT_CENTER_STU_DATA_PROC",第17行

ora - 06512:在第1行


查询时间:0.029 s


二,解决过程

通过百度发现,存储过程把这个参数作为了一个整体来处理了,并不象普通的sql一样,把他作为一个数组来对待


三,解决方案

百度了一下,发现网上方案挺多,但是我选择了以下的方案,就是自定义一个函数,对这个参数进行处理。

步骤一,新建一个oracle变量:(普通的sql查询窗口既可以创建)

CREATE 或是REPLACE  TYPE  strsplit_type  IS  TABLE  OF  VARCHAR2  (4000)

步骤二,新建一个函数(这个函数是网上现成的,亲测可用)

CREATE 或是REPLACE    function  strsplit (p_value  varchar2,   ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,p_split  varchar2 :=, & # 39; & # 39;)   return  strsplit_type   pipelined    v_idx 才能,,,,,,,整数;   v_str 才能,,,,,,,varchar2 (500);   v_strs_last 才能varchar2 (4000),:=, p_value;   开始   ,循环   ,,,v_idx :=, instr (p_split v_strs_last也);   ,,,exit  when  v_idx =, 0;   ,,,v_str ,,,,,,,=, substr (v_strs_last,, 1,, v_idx 作用;1);   ,,,v_strs_last :=, substr (v_strs_last, v_idx  +, 1);   ,,,pipe 行(v_str);   最终获得才能;循环;   pipe 才能行(v_strs_last);   返回才能;   最终获得strsplit;

步骤三,改造存储过程(将原先在(centerIds)的更改为:在(select * from表(strsplit (centerIds))))

CREATE 或是REPLACE    PROCEDURE “MONTH_RPT_CENTER_STU_DATA_PROC", (centerIds  VARCHAR2拷贝)   AS  mlockdate 日期;   开始/*   创建人:fengcl   创建时间:2018.1.23   更新人:   更新时间:   参数:中心编号(字符串类型)   功能:调用时,先从中间表删除指定中心的数据,再重新查询插入指定中心的数据到中间表   */袢≡卤ㄋㄈ掌?   select  trunc (sysdate & # 39; mm # 39;) + to_number(,名称),into  mlockdate    得到mdm_dic_option  where 代码=& # 39;monthReportDate& # 39;,以及dic_code=& # 39; system_set_001& # 39;;      if  mlockdate< trunc (sysdate),, then    得到rpt_month_stu_data 获delete ;   where  RPT_DATE>=add_months (trunc (sysdate & # 39; mm # 39;), 1),   ,,,以及RPT_DATE

到此,问题解决。

甲骨文存储过程的关键字使用