oracle根据_分割字符串,oracle分割字符串

1.定义类型TYPE   t_Array用于数据返回

TYPE t_Array IS TABLE OF VARCHAR2(4000) index by binary_integer;   --写在包package中  index by binary_integer类型的下标就是自增长,numbers类型在插入元素时,不需要初始化

2.定义函数f_Split--在包package中声明,在包体package body中实现具体方法

FUNCTION f_Split(pi_str In Varchar2, pi_separator In Varchar2)

RETURN t_ArrayIS

idx Number;

currentindex Number := 1;

strs t_Array;

v_str varchar2(4000) := pi_str;

BEGIN

IF pi_str IS NOT NULL AND pi_separator IS NOT NULL THEN

IF INSTR(v_str, pi_separator) <> 0 THEN --INSTR(a,b) 判断其是否含有指定的字符,a字符串是否含有b字符串

LOOP

EXIT WHEN v_str IS NULL;

EXIT WHEN INSTR(v_str, pi_separator) = 0;

idx := INSTR(v_str, pi_separator); --从v_str字符串中查找指定字符串pi_separator的位置【从1开始】

strs(currentindex) := SUBSTR(v_str, 0, idx - 1); --substr(字符串,截取开始位置,截取长度) 返回截取的字符串

currentindex := currentindex + 1; --索引向后增加1

v_str := SUBSTR(v_str, idx + 1); --重新赋值截取后的字符串 从idx+1向后截取字符串

END LOOP;

END IF;

END IF;

IF v_str IS NOT NULL THEN

strs(currentindex) := v_str;

END IF;

Return strs;

END;t_ArrayIS

idx Number;

currentindex Number := 1;

strs t_Array;

v_str varchar2(4000) := pi_str;

BEGIN

IF pi_str IS NOT NULL AND pi_separator IS NOT NULL THEN

IF INSTR(v_str, pi_separator) <> 0 THEN --INSTR(a,b) 判断其是否含有指定的字符,a字符串是否含有b字符串

LOOP

EXIT WHEN v_str IS NULL;

EXIT WHEN INSTR(v_str, pi_separator) = 0;

idx := INSTR(v_str, pi_separator); --从v_str字符串中查找指定字符串pi_separator的位置【从1开始】

strs(currentindex) := SUBSTR(v_str, 0, idx - 1); --substr(字符串,截取开始位置,截取长度) 返回截取的字符串

currentindex := currentindex + 1; --索引向后增加1

v_str := SUBSTR(v_str, idx + 1); --重新赋值截取后的字符串 从idx+1向后截取字符串

END LOOP;

END IF;

END IF;

IF v_str IS NOT NULL THEN

strs(currentindex) := v_str;

END IF;

Return strs;

END;

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值