orcale 替换函数

Oracle中的替换函数replace和translate函数

2017年11月21日 10:05:22

阅读数:478

1.translate 
语法:TRANSLATE(char, from, to) 
用法:返回将出现在from中的每个字符替换为to中的相应字符以后的字符串。 
若from比to字符串长,那么在from中比to中多出的字符将会被删除。 
三个参数中有一个是空,返回值也将是空值。 
举例:

select translate('abcdefga','abc','wo') 返回值 from dual;
  • 1
        返回值
        -------
        wodefgw
  • 1
  • 2
  • 3
  • 4

分析:该语句要将’abcdefga’中的’abc’转换为’wo’, 
由于’abc’中’a’对应’wo’中的’w’, 
故将’abcdefga’中的’a’全部转换成’w’; 
而’abc’中’b’对应’wo’中的’o’, 
故将’abcdefga’中的’b’全部转换成’o’; 
由于’abc’中的’c’在’wo’中没有与之对应的字符, 
故将’abcdefga’中的’c’全部删除; 
简单说来,就是将from中的字符转换为to中与之位置对应的字符, 
若to中找不到与之对应的字符,返回值中的该字符将会被删除。 
在实际的业务中,可以用来删除一些异常数据, 
比如表a中的一个字段t_no表示电话号码, 
而电话号码本身应该是一个由数字组成的字符串, 
为了删除那些含有非数字的异常数据, 
就用到了translate函数:

delete from a,
           where length(translate(trim(a.t_no),'0123456789'|| a.t_no,
                                            '0123456789')) <> length(trim(a.t_no));
  • 1
  • 2
  • 3

2.replace 
语法:REPLACE(char, search_string,replacement_string) 
用法:将char中的字符串search_string全部转换为字符串replacement_string。 
举例:

select REPLACE('fgsgswsgs', 'fk' ,'j') 返回值 from dual;
  • 1
        返回值
        ---------
        fgsgswsgs
  • 1
  • 2
  • 3
  • 4
select REPLACE('fgsgswsgs', 'sg' ,'eeerrrttt') 返回值 from dual;
  • 1
        返回值
        -----------------------
        fgeeerrrtttsweeerrrttts
  • 1
  • 2
  • 3
  • 4

分析:第一个例子中由于’fgsgswsgs’中没有与’fk’匹配的字符串, 
故返回值仍然是’fgsgswsgs’; 
第二个例子中将’fgsgswsgs’中的字符串’sg’全部转换为’eeerrrttt’。 
总结:综上所述,replace与translate都是替代函数, 
只不过replace针对的是字符串,而translate针对的是单个字符。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值