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_Array IS  
     
  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_Array IS  
     
  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
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值