Oracle 去除字符传中重复的记录 自定义函数
来源:互联网 发布:美国大学教育专业知乎 编辑:程序博客网 时间:2024/06/05 10:57
create or replace function RemoveSameStr(oldStr varchar2, sign varchar2) return varchar2 is /**************************************************** ** ** 函数名称:RemoveSameStr ** 参 数:【名称】 【类型 】 【说明】 ** oldStr varchar2 要处理的字符串 ** sign varchar2 字符串分隔符 ** 返 回 值:Result varchar2 不包含重复子串的记录 ** 摘 要:去除字符传中重复的记录 ** ** 当前版本:1.0 ** ** 作 者:HeavenBen ** 完成日期:2015年04月09日 ** 备 注: ****************************************************/ 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; --字符串太长 if length(oldStr) > 1000 then return(oldStr); 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 RemoveSameStr;
0 0
- Oracle 去除字符传中重复的记录 自定义函数
- oracle 去除重复字符函数
- oracle 去除重复的记录
- oracle sql 字符串去除重复字符函数
- ORACLE 去除重复记录
- oracle 去除重复记录
- ORACLE 去除多余的重复记录语句
- oracle查找重复记录,去除重复记录
- SQL去除重复记录(oracle)
- oracle去除数据库中重复记录的办法
- oracle 去除重复字符串函数
- Oracle SQL分析函数row_number()获取前n条记录、去除重复记录
- Oracle去除表中重复记录
- oracle数据库去除重复记录sql
- oracle——去除重复记录
- oracle去除重复记录 去重 sql去重 记录
- 1.3 去除字符串中重复的字符
- C# 去除字符串里的重复字符
- Linux 整理
- C++友元简介:友元函数,友元类和友元成员函数
- Linux下DIR,dirent,stat等结构体详解
- Java基础—集合框架(四)
- 螺旋矩阵
- Oracle 去除字符传中重复的记录 自定义函数
- 常见算法时间复杂度
- 杭电 HDU ACM 2048 神、上帝以及老天爷
- androidの异常:java.lang.IllegalStateException: ImageLoader must be init with configuration befor 错误解决方法
- WEKA连接MySQL
- 开灯问题 简单模拟法
- 银行家算法
- for循环流程
- 三个数中取出最大的两个