oracle中的替换函数replace和translate函数1.translate
语法:TRANSLATE(char, from, to)
⽤法:返回将出现在from中的每个字符替换为to中的相应字符以后的字符串。
若from⽐to字符串长,那么在from中⽐to中多出的字符将会被删除。
三个参数中有⼀个是空,返回值也将是空值。
举例:SQL> select translate('abcdefga','abc','wo') 返回值from dual;
返回值
-------
wodefgw
分析:该语句要将'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函数:
SQL> delete from a,
where length(translate(trim(a.t_no),
字符串replace函数
'0123456789' || a.t_no,
'0123456789')) <> length(trim(a.t_no));
语法:REPLACE(char, search_string,replacement_string)
⽤法:将char中的字符串search_string全部转换为字符串replacement_string。
举例:SQL> select REPLACE('fgsgswsgs', 'fk' ,'j') 返回值from dual;
返回值
---------
fgsgswsgs
SQL> select REPLACE('fgsgswsgs', 'sg' ,'eeerrrttt') 返回值from dual;
返回值
-----------------------
fgeeerrrtttsweeerrrttts
分析:第⼀个例⼦中由于'fgsgswsgs'中没有与'fk'匹配的字符串,
故返回值仍然是'fgsgswsgs';
第⼆个例⼦中将'fgsgswsgs'中的字符串'sg'全部转换为'eeerrrttt'。
总结:综上所述,replace与translate都是替代函数,
只不过replace针对的是字符串,⽽translate针对的是单个字符。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。