【經驗】【ORACLE】從字符串中截取其中的數字


方法一:

如果Oracle版本不是太低的話,使用 正則表達式函數 REGEXP_SUBSTR 處理。

REGEXP_SUBSTR有5個參數,分別是:
第一個是輸入的字符串
第二個是正則表達式
第三個是標識從第幾個字符開始正則表達式匹配。(默認為1)
第四個是標識第幾個匹配組。(默認為1)
第五個是是取值范圍:
i:大小寫不敏感;
c:大小寫敏感;
n:點號 . 不匹配換行符號;
m:多行模式;
x:擴展模式,忽略正則表達式中的空白字符。

例如:
SELECT REGEXP_SUBSTR('ABC123BCD456','[0-9]+') FROM DUAL;
--返回123

SELECT REGEXP_SUBSTR('ABC123BCD456','[0-9]+',6) FROM DUAL;
--返回3

SELECT REGEXP_SUBSTR('ABC123BCD456','[0-9]+',7) FROM DUAL;
--返回456

SELECT REGEXP_SUBSTR('ABC123BCD456','[0-9]+',1,2) FROM DUAL;
--返回456

方法二:

使用方法一只能截取其中其中的一段數字,如果想截取字符串中的所有數據,可以使用translate函數實現,具體使用方法如下:

select translate('&str' , '0123456789' || '&str' , '0123456789') from dual;

translate函數語法是TRANSLATE(string,from_str,to_str),

其功能是返回將(所有出現的)from_str中的每個字符替換為to_str中的相應字符以后的string。TRANSLATE 是 REPLACE 所提供的功能的一個超集。如果 from_str 比 to_str 長,
那么在 from_str 中而不在 to_str 中的額外字符將從 string 中被刪除,因為它們沒有相應的替換字符。to_str 不能為空。Oracle 將空字符串解釋為 NULL,並且如果TRANSLATE
中的任何參數為NULL,那么結果也是 NULL。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM