首頁  >  文章  >  資料庫  >  oracle的替換函數有哪些

oracle的替換函數有哪些

青灯夜游
青灯夜游原創
2022-02-24 18:12:3414214瀏覽

oracle的替換函數有:1、translate()函數,語法「TRANSLATE(char, from, to)」;2、replace()函數,語法「REPLACE(字串,查找值,替換值)」。

oracle的替換函數有哪些

本教學操作環境:Windows7系統、Oracle 11g版、Dell G3電腦。

oracle中的替換函數replace和translate函數

#1.translate

語法: TRANSLATE(char, from, to)

用法:傳回將出現在from中的每個字元替換為to中的對應字元以後的字串。

            若from比to字串長,那麼在from中比to中多出的字元將會被刪除。

            三個參數中有一個是空,而回傳值也會是空值。

範例:

SQL> select translate('abcdefga','abc','wo') 返回值 from dual;

傳回值

 wodefgw

分析:

該語句要將'abcdefga'中的'abc'轉換為'wo',由於'abc'中'a'對應'wo'中的'w',故將'abcdefga'中的'a'全部轉換成'w';

而'abc'中'b'對應'wo'中的'o',故將'abcdefga'中的'b'全部轉換成'o';

'abc'中的'c'在'wo'中沒有與之對應的字符,故將'abcdefga'中的'c'全部刪除;

簡單說來,就是將from中的字符轉換為to中與之位置對應的字符,若to中找不到與之對應的字符,返回值中的該字符將會被刪除。

在實際的業務中,可以用來刪除一些異常數據,例如表a中的一個字段t_no表示電話號碼,而電話號碼本身應該是一個由數字組成的字符串,為了刪除那些含有非數字的異常數據,就用到了translate函數:

SQL> delete from a,
          where length(translate(trim(a.t_no),
                   '0123456789' || a.t_no,
                             &#39;0123456789&#39;)) <> length(trim(a.t_no));

2.replace

語法:REPLACE(char, search_string,replacement_string)

用法:將char中的字串search_string全部轉換為字串replacement_string。

範例1:

SQL> select REPLACE(&#39;fgsgswsgs&#39;, &#39;fk&#39; ,&#39;j&#39;) 返回值 from dual;

傳回值

fgsgswsgs

範例2:

SQL> select REPLACE(&#39;fgsgswsgs&#39;, &#39;sg&#39; ,&#39;eeerrrttt&#39;) 返回值 from dual;

傳回值 

fgeeerrrtttsweeerrrttts

分析:

  • 第一個範例中由於'fgsgswsgs'中沒有與'fk'匹配的字串,故返回值仍然是'fgsgswsgs';

  • ##第二個例子中將'fgsgswsgs'中的字串'sg'全部轉換為'eeerrrttt'。

總結:綜上所述,replace與translate都是替代函數,只不過replace針對的是字串,而translate針對的是單一字元。

推薦教學:《

Oracle教學

以上是oracle的替換函數有哪些的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn