Oracle数据库存储过程 ,去除给定字符串中重复的字符串
来源:互联网 发布:java if while嵌套语句 编辑:程序博客网 时间:2024/05/19 02:25
以下函数是本人在编写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;
这个函数的功能主要是用于去除给定字符串中重复的字符串.在使用中需要指定字符串的分隔符.示例:
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数据库存储过程 ,去除给定字符串中重复的字符串
- 去除给定字符串中重复的字符串
- 给定一个字符串,去除整个字符串中重复的字符
- Oracle存储过程中去掉重复字符串的函数
- oracle 去除重复字符串函数
- 1.3 去除字符串中重复的字符
- 去除字符串中重复的字符
- 0056 去除字符串中重复的字符
- 去除字符串中重复出现的字符
- 给定字符串,要求除去字符串中重复出现的字符
- 找出给定字符串中第一个重复的字符串
- 去除字符串中重复字符
- 去除字符串中重复字符
- 找出给定字符串中第一个不重复的字符
- 给定字符串中有无重复字符?
- oracle sql 字符串去除重复字符函数
- Java去除字符串中重复出现的字符
- Visual Studio .NET使用技巧手册读书笔记之其他.NET提示与技巧
- 从asm_out_file看gcc汇编代码的生成
- 体验Java 1.5中面向方面(AOP)编程
- asp.net+javascript+css(模仿google的拖拽的个性网页布局)(操作数据库篇2)
- 从分布式系统的角度看REST
- Oracle数据库存储过程 ,去除给定字符串中重复的字符串
- mysql的一个简单的性能测试
- oracle SQL性能优化
- 最新作品 WEB设计-婚纱行业网站(程序+平面)
- 学习使用C#中的线程(1)
- ORACLE 测试题 看看你能答出多少?
- How to Drill Down to External url page. How to Pass url parameters
- new三种用法[转]
- 通过JDBC连接Oracle数据库中的十大技巧