oracle截取字符(substr)检索字符位置(instr)示例介绍
一:理论
oracle截取字符(substr),检索字符位置(instr)casewhenthenelseend语句使用收藏
常用函数:substr和instr
1.SUBSTR(string,start_position,[length])求子字符串,返回字符串
解释:string元字符串
start_position开始位置(从0开始)
length可选项,子字符串的个数
Forexample:
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:源字符串中第几次出现的子字符串
Forexample:
INSTR('CORPORATEFLOOR','OR',3,2)中,源字符串为'CORPORATEFLOOR',目标字符串为'OR',起始位置为3,取第2个匹配项的位置;返回结果为14'
二:实际测试
selectsubstr('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')Fromdual;
测试成功