Oracle存储过程中去掉重复字符串函数

以下函数是在编写Oracle数据库存储过程时写的函数,相信下文中的内容对大家会非常有帮助,重要的是该函数通用性比较强,故拿出来与大家分享,供大家参考,希望对大家能够有所帮助。

网站建设哪家好,找创新互联建站!专注于网页设计、网站建设、微信开发、微信平台小程序开发、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了湖滨免费建站欢迎大家使用!

这个函数的功能主要是用于去除给定字符串中重复的字符串.在使用中需要指定字符串的分隔符.示例:

str := MyReplace('13,14,13,444', ',');

输出:

13,14,444

create or replace function MyReplace(oldStr varchar2, sign varchar2) return varchar2 is

str varchar2(1000);

currentIndex number;

startIndex number;

endIndex number;

type str_type is table of varchar2(30)

index by binary_integer;

arr str_type;

Result varchar2(1000);

begin

if oldStr is null then

return ('');

end if;

str := oldStr;

currentIndex := 0;

startIndex := 0;

loop

currentIndex := currentIndex + 1;

endIndex := instr(str, sign, 1, currentIndex);

if (endIndex <= 0) then

exit;

end if;

arr(currentIndex) := trim(substr(str, startIndex + 1, endIndex - startIndex - 1));

startIndex := endIndex;

end loop;

取最后一个字符串:

arr(currentIndex) := substr(str, startIndex + 1, length(str));

去掉重复出现的字符串:

for i in 1.. currentIndex - 1 loop

for j in i + 1..currentIndex loop

if arr(i) = arr(j) then

arr(j) := '';

end if;

end loop;

end loop;

str := '';

for i in 1..currentIndex loop

if arr(i) is not null then

str := str || sign || arr(i);

数组置空:

arr(i) := '';

end if;

end loop;

去掉前面的标识符:

Result := substr(str, 2, length(str));

return(Result);

end MyReplace;

到这里,关于Oracle存储过程中去掉重复字符串函数的讲解就全部讲完了,希望大家都能够通过上文中的学习有所收获。

网页标题:Oracle存储过程中去掉重复字符串函数
文章源于:http://www.shufengxianlan.com/qtweb/news39/270739.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

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