Oracle存储过程中如何去掉重复字符串函数?
这个函数的功能主要是用于去除给定字符串中重复的字符串。在使用中需要指定字符串的分隔符。示例: str := MyReplace('13,14,13,444', ','); 输出: 13,14,444create 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 varchar...全部
这个函数的功能主要是用于去除给定字符串中重复的字符串。在使用中需要指定字符串的分隔符。示例: str := MyReplace('13,14,13,444', ','); 输出: 13,14,444create 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 取最后一个字符串: 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;。收起