新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
你说的异常是什么意思?如果是,执行中的错误,那么可以用“调试”,不过需要有一个系统权限的拥护才能调试,权限好象是什么debug XXXXX。
创新互联自2013年创立以来,是专业互联网技术服务公司,拥有项目成都网站设计、成都网站建设网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元渭源做网站,已为上家服务,为渭源各地企业和个人服务,联系电话:18980820575
如果说的是有时执行因为这样那样的数据问题出现的异常,那么一般都是通过exception来抛出异常的,这样的抛出的异常,你可以自己编代码,然后输入一张表内,这样就可以捕获异常了。如果1表示没有主键,2表示数据超长等等。具体的写法网上很多,这里就不写了。
如果用自定义异常则可以创建如下代码
Sql代码
declare
row_count int;
begin
select count(*) into row_count from tree_table where parent_id = '0001' ;
if (row_count 0) then
RAISE_APPLICATION_ERROR(-20001, '该节点有子节点,不能被删除。');
end if;
select count(*) into row_count from tree_table where id = '0001' and status 1 ;
if (row_count 0) then
RAISE_APPLICATION_ERROR(-20002, '该节点已被确认,不能被删除。');
end if;
delete from tree_table where id = '0001';
end;
举个例子:
create or replace trigger TRI_Test before insert on TABLE
for each row
declare
e_test exception;
begin
if inserting then
raise e;
end if;
end TRI_Test ;
把子存储过程中的异常处理去掉,父存储过程就能捕捉到异常了
当与一个异常错误相关的错误出现时,就会隐含触发该异常错误。用户定义的异常错误是通过显式使用 RAISE 语句来触发。当引发一个异常错误时,控制就转向到 EXCEPTION块异常错误部分,执行错误处理代码。
对于这类异常情况的处理,步骤如下:
1、在PL/SQL 块的定义部分定义异常情况:
异常情况 EXCEPTION;
2、RAISE 异常情况;
3、在PL/SQL 块的异常情况处理部分对异常情况做出相应的处理。
例:更新指定员工工资,增加100;
DECLARE
v_empno employees.employee_id%TYPE :=empno;
no_result EXCEPTION;
BEGIN
UPDATE employees SET salary = salary+100 WHERE employee_id = v_empno;
IF SQL%NOTFOUND THEN
RAISE no_result;
END IF;
EXCEPTION
WHEN no_result THEN
DBMS_OUTPUT.PUT_LINE('数据更新语句失败了!');
WHEN OTHERS THEN
DBMS_OUTPUT.PUT_LINE(SQLCODE||'---'||SQLERRM);
END;
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;
执行结果:
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;
执行结果:
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;
--这个是判断一个字符串是否为日期型的,如果异常就返回值0
CREATE
OR
REPLACE
FUNCTION
is_date(parameter
VARCHAR2)
RETURN
NUMBER
IS
val
DATE;
BEGIN
val
:=
TO_DATE(NVL(parameter,
'a'),
'yyyy-mm-dd
hh24:mi:ss');
RETURN
1;
EXCEPTION
WHEN
OTHERS
THEN
RETURN
0;
END;