oracle异常处理信息

Oracle 异常处理函数SQLCODE和SQLERRM

/*
异常处理函数
  异常处理函数用于取得Oracle错误号和错误信息,其中函数SQLCODE用于取得错误号,SQLERRM用于取得错误信息
  另外,通过使用内置过程raise_application_error,可以在创建子程序(过程、函数、包)时自定义错误号和错误信息
*/
declare
  v_empno emp.empno%type:=&empno;
  v_ename emp.ename%type:='&ename';
  v_deptno emp.deptno%type:=&deptno;
begin
  insert into emp(empno,ename,deptno) values(v_empno,v_ename,v_deptno);
  if sql%found then
    dbms_output.put_line('数据插入成功!');
    commit;
  end if;
  exception
    when others then
      dbms_output.put_line('错误号:'||sqlcode);
      dbms_output.put_line('错误信息:'||sqlerrm);
end;

在这里插入图片描述

/* 
  RAISE_APPLICATION_ERROR该过程用于在PL/SQL子程序中自定义错误信息
  语法格式:raise_application_error(error_number,message)
      error_number:用于定义错误号(-20000-20999)
      message:用于指定错误信息,长度不能超过2048个字节
*/
-- 创建存储过程
create or replace procedure change_sal(eno number,salary number)
is 
begin
  update emp set sal = salary where empno=eno;
  if sql%notfound then
    raise_application_error(-20002,'该员工不存在!');
  else
    dbms_output.put_line('更新成功!');
    commit;
  end if;
end;
 
-- 执行存储过程
begin
  change_sal(8888,800);
end;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值