translate函数语法:
translate(expr, from_strimg, to_string)
简介:
translate返回expr,个中from_string中的每一个字符的一切涌现都被to_string中的响应字符替换。expr中不在from_string中的字符不会被替换。假如expr是一个字符串,那末你必需把它放在单引号中。 from_string的参数能够包括比to_string更多的字符。在这类情况下,from_string末端的过剩字符在to_string中没有对应的字符。假如这些分外的字符涌现在字符中,那末它们将从返回值中移除。
您不能运用to_string的空字符串从返回值中删除from_string中的一切字符。Oracle数据库将空字符串解释为空,假如此函数具有空参数,则返回null。
translate供应了与replace函数相干的功用。 replace让你用一个字符串替换另一个字符串,以及删除字符串。 translate许可您在一个操纵中举行多个单字符,一对一的替换。
该函数不直接支撑CLOB数据。然则,CLOB能够经由过程隐式数据转换作为参数通报。
例子:
以下语句将一句话转换为具有下划线分开的字符串。from_string包括四个字符:井号,美圆标记,空格,星号。to_string只包括一个@标记和两个下划线。 这使得from_string中的第四个字符没有响应的替换,所以星号从返回的值中删除。
SELECT TRANSLATE('itmyhome#163.com$is my* email', '#$ *', '@__') from dual ---------- itmyhome@163.com_is_my_email
replace函数
语法:
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针对的是单个字符。
和replace函数的区分
select translate('itmyhome#163%com', '#%', '@.') from dual; select replace('itmyhome#163%com', '#%', '@.') from dual; --------- itmyhome@163.com itmyhome#163%com
上面的translate函数是将#替换为@,%替换为.
而replace却没有完成此结果,是因为没有找到#%团体的组合
相干引荐:
Oracle基本进修之子查询
Oracle—distinct的用法
Oracle 中 table 函数的运用浅析
以上就是详解Oracle中的translate函数和replace函数的细致内容,更多请关注ki4网别的相干文章!