oracle捕获异常和字符截取

来源:互联网 发布:制作单页用什么软件 编辑:程序博客网 时间:2024/06/05 22:35

--示例

begin

  for cur in (SELECT * FROM 临时表) loop
    update 表名 b
       set b.validdate = to_date(cur.t4, 'yyyy-mm-dd');
  end loop;

end;

--查询

SELECT NAME FROM ba_item_class bic WHERE bic.master_no || bic.small_no || bic.sub_small_no = '539975'  --条件列合并查询

--分组统计后获取最大
select max(pe) from (select s_no,SUM(money) as pe from pu_protocol where ID=48967 group by s_no) 

 --捕获异常

   select  * from test  --执行sql
    EXCEPTION
    WHEN OTHERS THEN
      BEGIN
--进入说明出现异常
       END;

--oracle字符截取

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 '

1 0
原创粉丝点击