给Oracle添加split和splitstr函数的方法_MySQL, Oracle及数据库讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  MySQL, Oracle及数据库讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 1620 | 回复: 0   主题: 给Oracle添加split和splitstr函数的方法        下一篇 
shijian111
注册用户
等级:新兵
经验:46
发帖:58
精华:0
注册:2012-2-15
状态:离线
发送短消息息给shijian111 加好友    发送短消息息给shijian111 发消息
发表于: IP:您无权察看 2015-5-6 14:58:50 | [全部帖] [楼主帖] 楼主

/* 

* Oracle 创建 split 和 splitstr 函数 

*/

/* 创建一个表类型 */

create or replace type tabletype as table of VARCHAR2(32676)

/

/* 创建 split 函数 */

CREATE OR REPLACE FUNCTION split (p_list CLOB, p_sep VARCHAR2 := ',')

RETURN tabletype

PIPELINED

/************************************** 

* Name: split 

* Author: Sean Zhang. 

* Date: 2012-09-03. 

* Function: 返回字符串被指定字符分割后的表类型。 

* Parameters: p_list: 待分割的字符串。 

p_sep: 分隔符,默认逗号,也可以指定字符或字符串。 

* Example: SELECT * 

FROM users 

WHERE u_id IN (SELECT COLUMN_VALUE 

FROM table (split ('1,2'))) 

返回u_id为1和2的两行数据。 

**************************************/

IS

l_idx PLS_INTEGER;

v_list VARCHAR2 (32676) := p_list;

BEGIN

LOOP

l_idx := INSTR (v_list, p_sep);

IF l_idx > 0

THEN

PIPE ROW (SUBSTR (v_list, 1, l_idx - 1));

v_list := SUBSTR (v_list, l_idx + LENGTH (p_sep));

ELSE

PIPE ROW (v_list);

EXIT;

END IF;

END LOOP;

END;

/

/* 创建 splitstr 函数 */

CREATE OR REPLACE FUNCTION splitstr (str IN CLOB,

i IN NUMBER := 0,

sep IN VARCHAR2 := ','

)

RETURN VARCHAR2

/************************************** 

* Name: splitstr 

* Author: Sean Zhang. 

* Date: 2012-09-03. 

* Function: 返回字符串被指定字符分割后的指定节点字符串。 

* Parameters: str: 待分割的字符串。 

i: 返回第几个节点。当i为0返回str中的所有字符,当i 超过可被分割的个数时返回空。 

sep: 分隔符,默认逗号,也可以指定字符或字符串。当指定的分隔符不存在于str中时返回sep中的字符。 

* Example: select splitstr('abc,def', 1) as str from dual; 得到 abc 

select splitstr('abc,def', 3) as str from dual; 得到 空 

**************************************/

IS

t_i NUMBER;

t_count NUMBER;

t_str VARCHAR2 (4000);

BEGIN

IF i = 0

THEN

t_str := str;

ELSIF INSTR (str, sep) = 0

THEN

t_str := sep;

ELSE

SELECT COUNT ( * )

INTO t_count

FROM table (split (str, sep));

IF i <= t_count

THEN

SELECT str

INTO t_str

FROM (SELECT ROWNUM AS item, COLUMN_VALUE AS str

FROM table (split (str, sep)))

WHERE item = i;

END IF;

END IF;

RETURN t_str;

END;

/

--转自 北京联动北方科技有限公司




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论