评论

收藏

[Oracle] 详解Oracle自定义异常示例

数据库 数据库 发布于:2021-10-17 11:41 | 阅读数:558 | 评论:0

1.弹出错误框:

示例代码:
declare 
v_count number;
begin 
select count(*) into v_count from dept;
if v_count < 10 then 
raise_application_error(-20001,'数量小于10');
end if;
end;
执行结果:

DSC0000.png

2.控制台显示:

示例代码:
declare 
v_count number;
my_exp exception;
begin 
select count(*) into v_count from dept;
if v_count < 10 then 
raise my_exp;
end if;
exception 
when my_exp then 
dbms_output.put_line('数量小于10');
when others then 
dbms_output.put_line('其他异常');
end;
执行结果:

DSC0001.png

PS:ORACLE 用户自定义异常小例子
CREATE OR REPLACE PROCEDURE test_Exception_byLeejin
(
ParameterA IN varchar,
ParameterB IN varchar,
ErrorCode OUT varchar --返回值,错误编码
)
AS
/*以下是一些变量的定义*/
V NUMBER;
V nvarchar();
V NUMBER; 
APP_EXP EXCEPTION; --自定义异常
BEGIN
ErrorCode :='';
IF (ParameterA=ParameterB) THEN
ErrorCode := 'ParameterA = ParameterB';
RAISE APP_EXP; -- 抛出异常
END IF;
EXCEPTION
WHEN APP_EXP THEN --在处理异常
RAISE_APPLICATION_ERROR(-,ErrorCode);
WHEN OTHERS THEN 
RAISE_APPLICATION_ERROR(-,'未知异常');
END;
关注下面的标签,发现更多相似文章