Oracle系统预定义的异常
比如:SELF_IS_NULL、VALUE_ERROR、ZERO_DIVIDE等Oracle中自带的异常类型
使用方法:
1 DECLARE 2 V_Result NUMBER(3); 3 BEGIN 4 V_Result = 2/0; 5 EXCEPTION 6 WHEN ZERO DIVIDE THEN 7 DBMS_OUTPUT.PUT_LINE('除数不能为0'); 8 RAISE; 9 END;
Oracle系统非预定义的异常(Others里面的异常)
如果发生了非预定义异常,可以用 WHEN OTHERS THEN 去处理
如果想定位某个非预定义异常,可以初始化该非预定义异常去使用
使用方法:
DECLARE DML_EXCEPTION EXCEPTION; -- 这里的-11111是某个异常的代码 PRAGMA EXCEPTION_INIT(DML_EXCEPTION,-11111) ; BEGIN --逻辑代码中如果发生了-11111这种类型的异常的话,就会触发 --DML_EXCEPTION EXCEPTION WHEN DML_EXCEPTION THEN DBMS_OUTPUT.PUT_LINE('DML exceptions'); END;
用户自定义的异常
如果想自己定义一种异常,比如部门工号为10001的人一旦有超过5000RMB的就触发这个异常
使用方法:
DECLARE SALARY_EXCEPTION EXCEPTION; V_Sal EMP.SAL%TYPE; BEGIN SELECT SAL INTO V_Sal FROM EMP WHERE JOB_ID = 10001; IF V_Sal > 5000 THEN RAISE SALARY_EXCEPTION; --通过RAISE去抛出这个异常 END IF; EXCEPTION WHEN SALARY_EXCEPTION THEN DBMS_OUTPUT.PUT_LINE('10001员工工资超过了5000!'); END;