据我了解,PL/SQL 中没有split函数,需要自己写。

create or replace type type_split as table of varchar2(50); --创建一个  type  ,如果为了使split函数具有通用性,请将其size 设大些。


--创建function

 
  
  1. create or replace function split  
  2. (  
  3.  p_list varchar2,  
  4.  p_sep varchar2 := ',' 
  5. return type_split pipelined  
  6.  is 
  7.  l_idx pls_integer;  
  8.  v_list varchar2(50) := p_list;  
  9. begin 
  10.  loop  
  11.  l_idx := instr(v_list,p_sep);  
  12.  if l_idx > 0 then 
  13.  pipe row(substr(v_list,1,l_idx-1));  
  14.  v_list := substr(v_list,l_idx+length(p_sep));  
  15.  else 
  16.  pipe row(v_list);  
  17.  exit;  
  18.  end if;  
  19.  end loop;  
  20.  return;  
  21. end split;  
  22.  
  23.  
  24. SQL> select * from table(split('northsnow,塞北的雪',','));  
  25.  
  26. COLUMN_VALUE  
  27. --------------------------------------------------  
  28. northsnow  
  29. 塞北的雪  
  30.  
  31. SQL>  


---------------------------------------------------------------------------------------------------------------

PL/SQL中定义数组

 
  
  1. declare 
  2. type tab_numbers is table of number; -- 定义数组类型  
  3. lt tab_numbers; -- 定义一个未初始化的数组  
  4. begin 
  5. lt := tab_numbers(); -- 初始化一个空数组,无任何元素  
  6. lt.extend; -- 扩展数组,扩展一个元素  
  7. lt(1) := 100; -- 数组下标从1开始  
  8. lt.extend(3); -- -- 扩展数组,扩展3个元素  
  9. lt(2) := 1002;  
  10. lt(3) := 1003;  
  11. lt(4) := 1004;  
  12. -- lt(5) := 0; 这里将不允许,因为不存在此下标之元素  
  13. for i in 1..lt.count loop -- lt.count 取得数组元素个数  
  14. dbms_output.put_line(lt(i));  
  15. end loop;  
  16. end;  


转载:http://hi.baidu.com/%BA%C3%D1%F2%BE%CD%BA%C3%D1%F9/blog/item/a42c40f3306939cf0a46e0af.html