oracle字符串如何简便去重? 比如说’123514543878645‘; 将字符内部重复的去掉变成‘12345678’。 5

我的思路是:1、先把字符串打散,变成很多字符串,用“,”隔开!2、去掉重复字符串!3、重新组合!想问有没有简单点的!!... 我的思路是:
1、先把字符串打散,变成很多字符串,用“,”隔开!
2、去掉重复字符串!
3、重新组合!
想问有没有简单点的!!
展开
 我来答
liangbr520
2015-04-17
知道答主
回答量:2
采纳率:0%
帮助的人:2698
展开全部
使用以下函数即可完成:

--字符串去重复字符函数
CREATE OR REPLACE FUNCTION remove_rame_string(
v_strings in varchar2
)
return varchar2
IS
v_strings1 varchar2(64) default ' ';
begin
v_strings1:=nvl(replace(rtrim(ltrim(v_strings)),' ',''),' ');

select listagg(c, '') within group(order by id2) into v_strings1
from (select distinct c,id2
from (select row_number() over(partition by e.v_strings1 order by substr(e.v_strings1, iter.pos, 1)) rn,
substr(e.v_strings1, iter.pos, 1) c,1 as id2
from (select v_strings1 from dual) e,
(select rownum pos from user_tables) iter
where iter.pos <= length(e.v_strings1)
order by 1));
return v_strings1 ;

end remove_rame_string;
/
百度网友61f144c3
2012-12-27 · TA获得超过4145个赞
知道小有建树答主
回答量:1224
采纳率:71%
帮助的人:382万
展开全部
目前只想到自定义函数 通过循环来实现。。。。

循环 将每个字符写入一个临时表
然后
select distinct col1 from tmp_tb
这个怎么样。。。
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
xu176032
2012-12-27
知道答主
回答量:12
采纳率:0%
帮助的人:8.5万
展开全部
用存储过程可以解决
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式