1. 程式人生 > 資料庫 >Oracle中的translate函式和replace函式的用法詳解

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
----------
[email protected]_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;
---------
[email protected]
itmyhome#163%com

上面的translate函式是將#替換為@,%替換為.

而replace卻沒有實現此效果,是因為沒有找到#%整體的組合

總結

以上所述是小編給大家介紹的Oracle中的translate函式和replace函式的用法詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回覆大家的。在此也非常感謝大家對我們網站的支援!