旗下导航:搜·么
当前位置:网站首页 > MySQL教程 > 正文

详解Oracle中的translate函数和replace函数【MySQL教程】,translate,Oracle,函数

作者:搜教程发布时间:2019-12-01分类:MySQL教程浏览:64评论:0


导读:translate返回expr,个中from_string中的每一个字符的一切涌现都被to_string中的响应字符替换,而replace函数将char中的字符串search_s...
translate返回expr,个中from_string中的每一个字符的一切涌现都被to_string中的响应字符替换,而replace 函数将char中的字符串search_string悉数转换为字符串replacement_string本文给人人分享Oracle中的translate函数和replace函数的用法,一同看看吧,希望能协助到人人。

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网别的相干文章!

标签:translateOracle函数


欢迎 发表评论: