一:理論
oracle 截取字符(substr),檢索字符位置(instr) case when then else end語(yǔ)句使用 收藏
常用函數(shù):substr和instr
1.SUBSTR(string,start_position,[length]) 求子字符串,返回字符串
解釋:string 元字符串
start_position 開(kāi)始位置(從0開(kāi)始)
length 可選項(xiàng),子字符串的個(gè)數(shù)
For example:
substr("ABCDEFG", 0); //返回:ABCDEFG,截取所有字符
substr("ABCDEFG", 2); //返回:CDEFG,截取從C開(kāi)始之后所有字符
substr("ABCDEFG", 0, 3); //返回:ABC,截取從A開(kāi)始3個(gè)字符
substr("ABCDEFG", 0, 100); //返回:ABCDEFG,100雖然超出預(yù)處理的字符串最長(zhǎng)度,但不會(huì)影響返回結(jié)果,系統(tǒng)按預(yù)處理字符串最大數(shù)量返回。
substr("ABCDEFG", -3); //返回:EFG,注意參數(shù)-3,為負(fù)值時(shí)表示從尾部開(kāi)始算起,字符串排列位置不變。
2.INSTR(string,subString,position,ocurrence)查找字符串位置
解釋:string:源字符串
subString:要查找的子字符串
position:查找的開(kāi)始位置
ocurrence:源字符串中第幾次出現(xiàn)的子字符串
For example:
INSTR('CORPORATE FLOOR','OR', 3, 2)中,源字符串為'CORPORATE FLOOR', 目標(biāo)字符串為'OR',起始位置為3,取第2個(gè)匹配項(xiàng)的位置;返回結(jié)果為 14 '
二:實(shí)際測(cè)試
select substr('OR:com.lcs.wc.placeholder.Placeholder:860825',INSTR('OR:com.lcs.wc.placeholder.Placeholder:860825',':', 1, 2)+1,length('OR:com.lcs.wc.placeholder.Placeholder:860825'))
,INSTR('OR:com.lcs.wc.placeholder.Placeholder:860825',':', 1, 2),
length('OR:com.lcs.wc.placeholder.Placeholder:860825') From dual;
測(cè)試成功
您可能感興趣的文章:- oracle使用instr或like方法判斷是否包含字符串
- oracle正則表達(dá)式regexp_like的用法詳解
- Oracle的substr和instr函數(shù)簡(jiǎn)單用法
- SQL中Charindex和Oracle中對(duì)應(yīng)的函數(shù)Instr對(duì)比
- Oracle中instr函數(shù)使用方法
- Oracle中Like與Instr模糊查詢性能大比拼