標籤:執行個體 解釋 bst case 開始 rpo 選項 測試 str
oracle 截取字元(substr),檢索字元位置(instr) case when then else end語句使用 收藏
常用函數:substr和instr
1.SUBSTR(string,start_position,[length]) 求子字串,返回字串
解釋:string 元字串
start_position 開始位置(從0開始)
length 可選項,子字串的個數
For example:
substr("ABCDEFG", 0); //返回:ABCDEFG,截取所有字元
substr("ABCDEFG", 2); //返回:CDEFG,截取從C開始之後所有字元
substr("ABCDEFG", 0, 3); //返回:ABC,截取從A開始3個字元
substr("ABCDEFG", 0, 100); //返回:ABCDEFG,100雖然超出預先處理的字串最長度,但不會影響返回結果,系統按預先處理字串最大數量返回。
substr("ABCDEFG", -3); //返回:EFG,注意參數-3,為負值時表示從尾部開始算起,字串排列位置不變。
2.INSTR(string,subString,position,ocurrence)尋找字串位置
解釋:string:源字串
subString:要尋找的子字串
position:尋找的開始位置
ocurrence:源字串中第幾次出現的子字串
For example:
INSTR(‘CORPORATE FLOOR‘,‘OR‘, 3, 2)中,源字串為‘CORPORATE FLOOR‘, 目標字串為‘OR‘,起始位置為3,取第2個匹配項的位置;返回結果為 14 ‘
測試欄位執行個體:
表:cheyang.content=’ request="" PackId="" PackPlanId="100003624470" sFlag="1" ‘
要求:截取PackPlanId的vlaue值
select substr(planid, 0, instr(planid, ‘"‘, 1, 1) - 1) planid --planid(100003624470" sFlag=)截取”之前的字串
into v_PackPlanId
from (select substr(content,INSTR(content, ‘PackPlanId‘, 1, 1) + 11+1,20) planid --packPlanId=長度是11+1(1),向後截取20個字元
from sducy.cheyang
where t.oid = v_oid);
測試結果:
planid
100003624470
Oracle截取字串和尋找字串,聯合使用截取特定字元