oracle符串怎么分割 oracle 字符串切割函数

Oracle中有字符串分割函数吗

第一种:oracle字符串分割和提取

创新互联长期为成百上千客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为扎赉特企业提供专业的成都做网站、网站设计,扎赉特网站改版等技术服务。拥有10余年丰富建站经验和众多成功案例,为您定制开发。

分割

create or replace function Get_StrArrayLength

(

av_str varchar2,  --要分割的字符串

av_split varchar2  --分隔符号

)

return number

is

lv_str varchar2(1000);

lv_length number;

begin

lv_str:=ltrim(rtrim(av_str));

lv_length:=0;

while instr(lv_str,av_split)0 loop

lv_length:=lv_length+1;

lv_str:=substr(lv_str,instr(lv_str,av_split)+length(av_split),length(lv_str));

end loop;

lv_length:=lv_length+1;

return lv_length;

end Get_StrArrayLength;

提取

create or replace function Get_StrArrayStrOfIndex

(

av_str varchar2,  --要分割的字符串

av_split varchar2,  --分隔符号

av_index number --取第几个元素

)

return varchar2

is

lv_str varchar2(1024);

lv_strOfIndex varchar2(1024);

lv_length number;

begin

lv_str:=ltrim(rtrim(av_str));

lv_str:=concat(lv_str,av_split);

lv_length:=av_index;

if lv_length=0 then

lv_strOfIndex:=substr(lv_str,1,instr(lv_str,av_split)-length(av_split));

else

lv_length:=av_index+1;

lv_strOfIndex:=substr(lv_str,instr(lv_str,av_split,1,av_index)+length(av_split),instr(lv_str,av_split,1,lv_length)-instr(lv_str,av_split,1,av_index)-length(av_split));

end if;

return  lv_strOfIndex;

end Get_StrArrayStrOfIndex;

oracle里面怎么分割字符串

(1)定义split_type类型:

CREATE OR REPLACE TYPE split_type IS TABLE OF VARCHAR2 (4000) /

(2)定义split函数:

CREATE OR REPLACE FUNCTION split (p_str IN VARCHAR2, p_delimiter IN VARCHAR2) RETURN split_type IS j INT := 0; i INT := 1; len INT := 0; len1 INT := 0; str VARCHAR2 (4000); my_split split_type := split_type (); BEGIN len := LENGTH (p_str); len1 := LENGTH (p_delimiter); WHILE j len LOOP j := INSTR (p_str, p_delimiter, i); IF j = 0 THEN j := len; str := SUBSTR (p_str, i); my_split.EXTEND; my_split (my_split.COUNT) := str; IF i = len THEN EXIT; END IF; ELSE str := SUBSTR (p_str, i, j - i); i := j + len1; my_split.EXTEND; my_split (my_split.COUNT) := str; END IF; END LOOP; RETURN my_split; END split; /

(3)存储过程中,使用类似

For T In ( select a,b,c,d from table (split('1,2,3,4',',')) ) Loop

--注意下面的inserti语句,varchar类型的值需要补充引号上去

Execute Immediate ' insert into tableName set fieldName = '||T.a ;

Execute Immediate 'commit';

End Loop;

的查询语句,把分开的结果拼成sql语句并写入到表中。

ORACLE 怎么拆分字符串

拆分sql后:

select 

substr('Hello World',0,instr('Hello World','o')) as 首,

substr('Hello World',instr('Hello World','o')+1) as 尾

from dual;

有什么规定吗?

“ABCDEFGH”或是“A,B,C,D,E,F,G,H"

按符号拆分?按位置拆分?

substr()函数:截取a-b之间的或a 。如:substr('Hello World',0,5)截取1-5或

substr('Hello World',0,instr('Hello World','o'))截取1-"o"的位置

1.如果是","等符号:

select substr('Hello World',0,instr('Hello World','o'))  from dual;

select substr('Hello World',instr('Hello World','o')+1)  from dual;

select substr('Hello World',instr('Hello World','o')+1,length('Hello World'))  from dual;

新闻名称:oracle符串怎么分割 oracle 字符串切割函数
标题来源:https://www.cdcxhl.com/article32/hpiepc.html

成都网站建设公司_创新互联,为您提供静态网站网站建设品牌网站建设网站收录手机网站建设虚拟主机

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

成都定制网站网页设计