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;   

 

 

 

 

 

你可能感兴趣的:(ORACLE)