网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

oracle逗号怎么拆 oracle逗号拆分行

oracle如何拆分以逗号分隔的字符串为多列

oracle 中可以用connect by把字符串按都好分割:

成都创新互联公司专业提供成都主机托管四川主机托管成都服务器托管四川服务器托管,支持按月付款!我们的承诺:贵族品质、平民价格,机房位于中国电信/网通/移动机房,重庆服务器托管服务有保障!

比如定义字符串:

pv_no_list :='23,34,45,56';

SELECT DISTINCT REGEXP_SUBSTR (pv_no_list,'[^,]+',1,LEVEL) as "token"

FROM DUAL

CONNECT BY REGEXP_SUBSTR (pv_no_list,'[^,]+',1,LEVEL) IS NOT NULL

order by 1

返回结果:

TOKEN

23

34

45

56

Oracle高手请接招:以逗号为分隔符把一列拆成3列

oracle 中可以用connect by把字符串按都好分割:

比如定义字符串:

pv_no_list :='23,34,45,56';

SELECT DISTINCT REGEXP_SUBSTR (pv_no_list,'[^,]+',1,LEVEL) as "token"

FROM DUAL

CONNECT BY REGEXP_SUBSTR (pv_no_list,'[^,]+',1,LEVEL) IS NOT NULL

order by 1

返回结果:

TOKEN

23

34

45

56

Oracle中怎样用存储过程将一段字符串以逗号为界截取,并将得到的子串存到另一张表中

--通过游标遍历调用方法拆取存表:

--方法

create or replace function f_test_substr(

prm1 varchar2,    --地

prm2 varchar2 ,   --名称

prm3 varchar2,    --IP

prm4 varchar2    --结果

)

return varchar2

as

v_n int:=0;  --第几次取

v_l int;  --:截取次数

v_s varchar2(2000);  --处理拆分字符串

v_s1 varchar2(200);  --本次拆分

v_s2 varchar2(200);  --本次剩余

v_type varchar2(100);  --设备类型

v_code varchar2(100);  --设备编号

v_desc varchar2(100);  --设备描述

v_errmsg varchar2(200);

begin

v_l:=length(prm4)-length(replace(prm4,';',''));

v_s:=prm4||';';

v_s1:=substr(v_s,1,instr(v_s,';',1,1));

v_s2:=replace(v_s,v_s1,'');

while v_n=v_l loop

v_s2:=replace(v_s2,v_s1,'');

v_s1:=substr(v_s1,1,length(v_s1)-1);

v_type:=substr(v_s1,1,instr(v_s1,',',1,1)-1);

v_code:=substr(v_s1,instr(v_s1,',',1,1)+1,instr(v_s1,',',1,2)-instr(v_s1,',',1,1)-1);

v_desc:=substr(v_s1,instr(v_s1,',',1,2)+1,instr(v_s1||',',',',1,3)-instr(v_s1,',',1,2)-1);

insert into t_test_str(a,b,c,d,e,f) values(prm1,prm2,prm3,substr(v_type,instr(v_type,']',1)+1),v_code,v_desc);

v_n:=v_n+1;

v_s1:=substr(v_s2,1,instr(v_s2,';',1,1));

end loop;

commit;

return '成功';

exception

when others then

v_errmsg:=substr(sqlerrm,1,200);

return v_errmsg ;

end;

--存过

create or replace procedure p_test_substr1(o_result out varchar2)

as

v_a varchar2(20);

v_b varchar2(20);

v_c varchar2(20);

v_d varchar2(2000);

v_num int;

cursor c_str is

SELECT * from t_test_substr

;

begin

select count(1) into v_num from t_test_substr;

while v_num0 loop

open c_str;

loop

FETCH c_str INTO

v_a,v_b,v_c,v_d;

EXIT WHEN c_str%NOTFOUND;

o_result:=f_test_substr(v_a,v_b,v_c,v_d);

v_num:=v_num-1;

end loop;

CLOSE c_str;

end loop;

end;

效果见图:


当前名称:oracle逗号怎么拆 oracle逗号拆分行
当前URL:http://bjjierui.cn/article/hpihec.html

其他资讯