生活随笔
收集整理的這篇文章主要介紹了
【经验】【ORACLE】从字符串中截取其中的数字
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
方法一:
如果Oracle版本不是太低的話(huà),使用 正則表達(dá)式函數(shù) REGEXP_SUBSTR 處理。
REGEXP_SUBSTR有5個(gè)參數(shù),分別是:
第一個(gè)是輸入的字符串
第二個(gè)是正則表達(dá)式
第三個(gè)是標(biāo)識(shí)從第幾個(gè)字符開(kāi)始正則表達(dá)式匹配。(默認(rèn)為1)
第四個(gè)是標(biāo)識(shí)第幾個(gè)匹配組。(默認(rèn)為1)
第五個(gè)是是取值范圍:
i:大小寫(xiě)不敏感;
c:大小寫(xiě)敏感;
n:點(diǎn)號(hào) . 不匹配換行符號(hào);
m:多行模式;
x:擴(kuò)展模式,忽略正則表達(dá)式中的空白字符。
例如:
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
方法二:
使用方法一只能截取其中其中的一段數(shù)字,如果想截取字符串中的所有數(shù)據(jù),可以使用translate函數(shù)實(shí)現(xiàn),具體使用方法如下:
select translate('&str' , '0123456789' || '&str' , '0123456789') from dual;
translate函數(shù)語(yǔ)法是TRANSLATE(string,from_str,to_str),
其功能是返回將(所有出現(xiàn)的)from_str中的每個(gè)字符替換為to_str中的相應(yīng)字符以后的string。TRANSLATE 是 REPLACE 所提供的功能的一個(gè)超集。如果 from_str 比 to_str 長(zhǎng),
那么在 from_str 中而不在 to_str 中的額外字符將從 string 中被刪除,因?yàn)樗鼈儧](méi)有相應(yīng)的替換字符。to_str 不能為空。Oracle 將空字符串解釋為 NULL,并且如果TRANSLATE
中的任何參數(shù)為NULL,那么結(jié)果也是 NULL。
轉(zhuǎn)載于:https://www.cnblogs.com/AzikPhil/archive/2012/06/12/note_oracle_exp.html
總結(jié)
以上是生活随笔為你收集整理的【经验】【ORACLE】从字符串中截取其中的数字的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。