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'; 串'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中的translate函數與replace函數的詳細內容。更多資訊請關注PHP中文網其他相關文章!