日期:2014-05-16  浏览次数:20547 次

Oracle截取字符串和查找字符串,字符串长度,Case语法

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 '

?

?

select ename,
case 
when sal<1000 then 'lower' 
when sal>1001 and sal<2000 then 'modest' 
when sal>2001 and sal<4000 then 'high' 
else 'too high' 
end 
from emp;

select a.gno, a.lno from(
         select (case when length(lno) < 7 then '' when substr(lno, 0, 1) = '9' then substr(lno, 7, length(lno)) else substr(lno, 6, length(lno)) end) as gno, lno from t_table where id<100) a
 group by a.gno, a.lno order by a.gno;