ITPub博客

首页 > Linux操作系统 > Linux操作系统 > <转>oracle split function

<转>oracle split function

原创 Linux操作系统 作者:taogchan 时间:2012-04-22 12:54:27 0 删除 编辑
Sql代码  收藏代码
  1. CREATE OR REPLACE TYPE str_split IS TABLE OF VARCHAR2 (4000)  
 

 

 

Sql代码  收藏代码
  1. CREATE OR REPLACE FUNCTION splitstr(p_string IN VARCHAR2,  
  2. p_delimiter IN VARCHAR2)  
  3. RETURN str_split  
  4. PIPELINED  
  5. AS  
  6. v_length NUMBER := LENGTH(p_string);  
  7. v_start NUMBER := 1;  
  8. v_index NUMBER;  
  9. BEGIN  
  10. LOOP  
  11. v_index := INSTR(p_string, p_delimiter, v_start);  
  12. IF v_index = 0  
  13. THEN  
  14. PIPE ROW(SUBSTR(p_string, v_start));  
  15. EXIT;  
  16. ELSE  
  17. PIPE ROW(SUBSTR(p_string, v_start, v_index - v_start));  
  18. v_start := v_index + 1;  
  19. END IF;  
  20. END LOOP;  
  21. RETURN;  
  22. END splitstr;  
 

 

 

测试:

 

SQL> select * from table(split('northsnow,塞北的雪',','));

 

COLUMN_VALUE

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

northsnow

 

塞北的雪

 

SQL> 



补充: 
-----PIPELINED关键字是什么意思? 
---- pipe row是什么意思?

pipelined声名此function是pipe的,如果这么声名了,就必须使用pipe row的方式把数据返回,常规函数最后的"return 变量",就变成了"return". 

pipelined的function主要是为了提高效率,不用等所有的数据都处理完成了才返回客户端,它是边处理边返回.适用于大数据量的交互

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/22392018/viewspace-721947/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论

注册时间:2009-08-28

  • 博文量
    200
  • 访问量
    1183306