擷取oracle字串中的數字

2022-06-09 18:06:08 字數 2283 閱讀 8783

方法一:

如果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。

方法一:

如果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。

在字串中擷取數字

1.可以通過regexp substr函式 配合正規表示式 來實現。舉例 sql select regexp substr cyj8 abc 0 9 from dual 以上sql執行結果 8 備註 regexp substr函式格式如下 function regexp substr string,...

ORACLE字串擷取

substr 函式 擷取字串 語法 substr string,start,length string 表示源字串,即要擷取的字串。start 開始位置,從1開始查詢。如果start是負數,則從string字串末尾開始算起。length 可選項,表示擷取字串長度。示例 select substr h...

oracle中擷取字串

substring 返回字元 binary text 或 image 表示式的一部分。有關可與該函式一起使用的有效 microsoft sql server 資料型別的更多資訊,請參見資料型別。語法 substring expression start length 引數 expression 是字...