oracle 实现 split 函数 (返回数组)
来源:互联网 发布:js 浏览器版本号 编辑:程序博客网 时间:2024/06/06 12:20
如果你的存储过程的参数个数不定,比如你要处理A条件、B条件2种情况,或者A条件、C条件、F条件的情况,
每次的条件的个数和条件都是变动的,这样你的存储过程参数就不好做。这种情况下,你可以只输入一个参数,
多个条件用特殊字符如逗号分隔,然后对这个条件截断拆分之后循环处理,类似于jquery的split方法。然而,oracle
并没有这样的函数,你需要自己编写,以下是收录的一个有用的将oracle字符串截断成数组(oracle复合数据类型)的function。
CREATE OR REPLACE PACKAGE StatisPackageAS TYPE StatisList IS REF CURSOR; TYPE ty_str_split IS TABLE OF VARCHAR2 (4000); PROCEDURE Statis_Planning(PlanningId IN nvarchar2,SolutionID IN nvarchar2,indextypeid in NUMBER,cversionid IN nvarchar2,Indicators in nvarchar2,p_cur out StatisList); FUNCTION fn_split (p_str IN VARCHAR2, p_delimiter IN VARCHAR2) return ty_str_split; END StatisPackage;
测试:
DECLARE
CURSOR c
IS
SELECT *
FROM TABLE (CAST (fn_split ('1;;12;;123;;1234;;12345', ';;') AS ty_str_split
)
);
r c%ROWTYPE;
BEGIN
OPEN c;
LOOP
FETCH c INTO r;
EXIT WHEN c%NOTFOUND;
DBMS_OUTPUT.put_line (r.column_value);
END LOOP;
CLOSE c;
END;
/
结果:
1
12
123
1234
12345
方法二;
create or replace function f_split_string (var_str varchar2,var_split varchar2)
return t_ret_table
is
var_out t_ret_table; --定义变量
var_tmp varchar2(100);
var_element varchar2(100);
begin
var_tmp := var_str;
var_out := t_ret_table();
--如果存在匹配的分割符
while instr(var_tmp,var_split)>0 loop
var_element:=substr(var_tmp,1,instr(var_tmp,var_split)-1);
var_tmp := substr(var_tmp,instr(var_tmp,var_split)+length(var_split),length(var_tmp));
var_out.extend(1);
var_out(var_out.count) := var_element;
end loop;
var_out.extend(1);
var_out(var_out.count) := var_tmp;
return var_out;
end f_split_string;
在代码里,uni_array是一个table of varchar2的数组,就可以uni_array:=f_split_string('aa,bb,cc,dd',',')
将aa、bb、cc、dd四个元素装入uni_array,然后循环处理。
- Oracle 实现 split 函数 (返回数组)
- oracle 实现 split 函数 (返回数组)
- oracle 实现 split 函数 (返回数组)
- oracle 实现 split 函数 (返回数组)
- Oracle 实现split函数
- oracle实现split函数
- Oracle实现split函数
- oracle实现split函数
- Oracle实现split函数2
- Oracle的split函数, 数组应用必备
- oracle实现字符串分割函数 split()函数
- ORACLE(PL/SQL) 根据字符分割(SPLIT)字符串返回数组
- oracle split函数(自定义)
- SQL自定义函数split 将数组(分隔字符串)返回阵列(表)
- SQL自定义函数split 将数组(分隔字符串)返回阵列(表)
- SQL自定义函数split 将数组(分隔字符串)返回阵列(表)
- asp当中用了split函数必返回数组
- Oracle实现类似SPLIT函数功能
- js-----document//寻找节点
- Dreamweaver建立站点过程
- 10个Android开源个性化View控件
- Genymotion常见Bug
- 如何将字典的无序key按照A-Z排序
- oracle 实现 split 函数 (返回数组)
- Unix/Linux脚本中"set -e"的作用
- Java解析XML的四种方法
- Paxos算法
- 淘宝如何应对服务器高负载
- Spark集群搭建
- 淘宝用的是什么服务器
- python中ascii码和字符的转换
- IOS8布局之Autolayout与Size classes(一)