Oracle中的translate函數(shù)和replace函數(shù)的用法詳解
translate函數(shù)語(yǔ)法:
translate(expr, from_strimg, to_string)
簡(jiǎn)介:
translate返回expr,其中from_string中的每個(gè)字符的所有出現(xiàn)都被to_string中的相應(yīng)字符替換。expr中不在from_string中的字符不會(huì)被替換。如果expr是一個(gè)字符串,那么你必須把它放在單引號(hào)中。 from_string的參數(shù)可以包含比to_string更多的字符。在這種情況下,from_string末尾的多余字符在to_string中沒(méi)有對(duì)應(yīng)的字符。如果這些額外的字符出現(xiàn)在字符中,那么它們將從返回值中移除。
您不能使用to_string的空字符串從返回值中刪除from_string中的所有字符。Oracle數(shù)據(jù)庫(kù)將空字符串解釋為空,如果此函數(shù)具有空參數(shù),則返回null。
translate提供了與replace函數(shù)相關(guān)的功能。 replace讓你用一個(gè)字符串替換另一個(gè)字符串,以及刪除字符串。 translate允許您在一個(gè)操作中進(jìn)行多個(gè)單字符,一對(duì)一的替換。
該函數(shù)不直接支持CLOB數(shù)據(jù)。但是,CLOB可以通過(guò)隱式數(shù)據(jù)轉(zhuǎn)換作為參數(shù)傳遞。
例子:
以下語(yǔ)句將一句話轉(zhuǎn)換為具有下劃線分隔的字符串。from_string包含四個(gè)字符:井號(hào),美元符號(hào),空格,星號(hào)。to_string只包含一個(gè)@符號(hào)和兩個(gè)下劃線。 這使得from_string中的第四個(gè)字符沒(méi)有相應(yīng)的替換,所以星號(hào)從返回的值中刪除。
SELECT TRANSLATE('itmyhome#163.com$is my* email', '#$ *', '@__') from dual
----------
itmyhome@163.com_is_my_email
replace函數(shù)
語(yǔ)法:
REPLACE(char, search_string,replacement_string)
用法:
將char中的字符串search_string全部轉(zhuǎn)換為字符串replacement_string。
舉例:
SQL> select REPLACE('fgsgswsgs', 'fk' ,'j') 返回值 from dual;
返回值
---------
fgsgswsgs
SQL> select REPLACE('fgsgswsgs', 'sg' ,'eeerrrttt') 返回值 from dual;
返回值
-----------------------
fgeeerrrtttsweeerrrttts
分析:
第一個(gè)例子中由于'fgsgswsgs'中沒(méi)有與'fk'匹配的字符串,
故返回值仍然是'fgsgswsgs';
第二個(gè)例子中將'fgsgswsgs'中的字符串'sg'全部轉(zhuǎn)換為'eeerrrttt'。
總結(jié):綜上所述,replace與translate都是替代函數(shù),
只不過(guò)replace針對(duì)的是字符串,而translate針對(duì)的是單個(gè)字符。
和replace函數(shù)的區(qū)別
select translate('itmyhome#163%com', '#%', '@.') from dual;
select replace('itmyhome#163%com', '#%', '@.') from dual;
---------
itmyhome@163.com
itmyhome#163%com
上面的translate函數(shù)是將#替換為@,%替換為.
而replace卻沒(méi)有實(shí)現(xiàn)此效果,是因?yàn)闆](méi)有找到#%整體的組合
總結(jié)
以上所述是小編給大家介紹的Oracle中的translate函數(shù)和replace函數(shù)的用法詳解,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
Oracle安裝遇到INS-30131錯(cuò)誤的解決方法
這篇文章主要介紹了Oracle安裝遇到錯(cuò)誤INS-30131的解決方法,感興趣的小伙伴們可以參考一下2016-07-07
Oracle?function函數(shù)返回結(jié)果集的3種方法
工作中常需要經(jīng)過(guò)一段復(fù)雜邏輯處理后,得出的一個(gè)結(jié)果集,所以這篇文章主要給大家介紹了關(guān)于Oracle?function函數(shù)返回結(jié)果集的3種方法,需要的朋友可以參考下2023-07-07
解決PL/SQL修改Oracle存儲(chǔ)過(guò)程編譯就卡死的問(wèn)題
這篇文章主要介紹了PL/SQL修改Oracle存儲(chǔ)過(guò)程編譯就卡死,本文給大家分享問(wèn)題原因及解決方法,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-01-01
Oracle rac環(huán)境的數(shù)據(jù)庫(kù)導(dǎo)入操作步驟
Oracle RAC是一種基于共享存儲(chǔ)和共享數(shù)據(jù)庫(kù)的集群解決方案,可以將多個(gè) Oracle 數(shù)據(jù)庫(kù)實(shí)例連接成一個(gè)邏輯上的單一數(shù)據(jù)庫(kù),提供高可用性、靈活性和可伸縮性,本文給大家介紹Oracle rac環(huán)境的數(shù)據(jù)庫(kù)導(dǎo)入操作,感興趣的朋友一起看看吧2023-06-06
oracle設(shè)置密碼復(fù)雜度及設(shè)置超時(shí)退出的功能
我們都知道密碼策略加固的參數(shù)一般包括密碼長(zhǎng)度、復(fù)雜度檢測(cè)、最大最小使用時(shí)間、過(guò)期警報(bào)時(shí)間、最大登錄失敗次數(shù)以及鎖定時(shí)間等設(shè)置,下面這篇文章主要給大家介紹了關(guān)于oracle設(shè)置密碼復(fù)雜度及設(shè)置超時(shí)退出功能的相關(guān)資料,需要的朋友可以參考下2022-06-06
Oracle數(shù)據(jù)庫(kù)數(shù)據(jù)遷移完整解決步驟
我們常常需要對(duì)數(shù)據(jù)進(jìn)行遷移,遷移到更性能配置更高級(jí)的主機(jī)OS上、遷移到遠(yuǎn)程的機(jī)房、遷移到不同的平臺(tái)下,這篇文章主要給大家介紹了關(guān)于Oracle數(shù)據(jù)庫(kù)數(shù)據(jù)遷移的相關(guān)資料,需要的朋友可以參考下2024-02-02
Oracle內(nèi)存分配不足的過(guò)程解析(業(yè)務(wù)干掛數(shù)據(jù)庫(kù))
本文介紹了Oracle數(shù)據(jù)庫(kù)內(nèi)存分配不足的問(wèn)題,原因主要是業(yè)務(wù)劇增導(dǎo)致的內(nèi)存不足,通過(guò)分析AAS負(fù)載、等待事件、transactions和阻塞情況,發(fā)現(xiàn)PGA內(nèi)存出現(xiàn)了嚴(yán)重抖動(dòng),感興趣的朋友一起看看吧2025-02-02

