日期:2014-05-16  浏览次数:20718 次

Oracle异常处理
--异常处理---------------------//   
--预定义异常   
    --NO_DATA_FOUND     没有数据满足查询要求   
    --ZERO_DIVIDE       算术错误,如试图用0去除一个数   
    --INVALID_NUMBER    在要求数据的地方使用了非数据   
    --NOT_LOGGED_ON     没有连接上Oracle   
    --TOO_MANY_ROWS     SELECT INTO 返回多行记录   
    --VALUE_ERROR       遇到算术的、转换的、截去的或约束错误   
    --CURSOR_ALREADY_OPEN   试图打开一个已经打开的游标   
    --DUP_VAL_ON_INDEX  试图插入一个已经存在的唯一约束值   
    --LOGIN_DENIED      要求进入系统的请求被拒绝   
    --TIMEOUT_ON_RESOURCE   等待的系统时间已经超时   
    --OTHERS        其它异常   
  
--NO_DATA_FOUND 异常-----------------------------------------------//   
--%TYPE是指定义一个变量和数据库中某个表的某个字段的数据类型一样   
DECLARE   
    v_name emp.ename%TYPE;   
BEGIN   
    SELECT ename INTO v_name FROM emp WHERE empno='1234';  --异常发生,empno 中没有1234  
    DBMS_OUTPUT.PUT_LINE('Name is : ' || v_name);   
EXCEPTION   
    WHEN NO_DATA_FOUND THEN   
        DBMS_OUTPUT.PUT_LINE('No Data Found');   
    WHEN OTHERS THEN   
        DBMS_OUTPUT.PUT_LINE('Unknown Error');   
END;   
/   
--ZERO_DIVIDE 异常-------------------------------------------------//   
BEGIN   
    DBMS_OUTPUT.PUT_LINE(5/0);  --异常发生,不能被0除   
EXCEPTION   
    WHEN ZERO_DIVIDE THEN   
        DBMS_OUTPUT.PUT_LINE('Can not divide zero');   
    WHEN OTHERS THEN   
        DBMS_OUTPUT.PUT_LINE('Unknown Error');   
END;   
/   
--TOO_MANY_ROWS 异常-----------------------------------------------//   
DECLARE   
    no emp.empno%TYPE;   
    name emp.ename%TYPE;   
    dept emp.deptno%TYPE;   
BEGIN   
    SELECT empno,ename,deptno INTO no,name,dept FROM emp WHERE empno = 7369;   
    DBMS_OUTPUT.PUT_LINE('员工号 :' || no);   
    DBMS_OUTPUT.PUT_LINE('员工名 :' || name);   
    DBMS_OUTPUT.PUT_LINE('部门号 :' || dept);   
EXCEPTION   
    WHEN NO_DATA_FOUND THEN   
        DBMS_OUTPUT.PUT_LINE('7369雇员不存在');  --未找到数据   
    WHEN TOO_MANY_ROWS THEN   
        DBMS_OUTPUT.PUT_LINE('有多个学员号是7369');  --返回多行   
    WHEN OTHERS THEN   
        DBMS_OUTPUT.PUT_LINE('Unknown Error');   
END;   
/   
--DUP_VAL_ON_INDEX 异常--------------------------------------------//   
BEGIN   
    INSERT INTO emp   
    VALUES('7788','LaoZhao','Soft','7689','03-12月-81','2600','0','20');   
EXCEPTION   
    WHEN DUP_VAL_ON_INDEX THEN   
        DBMS_OUTPUT.PUT_LINE('违反了PRIMARY KEY约束:7788雇员已经存在');   
    WHEN OTHERS THEN   
        DBMS_OUTPUT.PUT_LINE('Unknown Error');   
END;   
/   
-------------------------------//   
--如果员工7788的工资小于3000,则更新为3000,如未找到该雇员,则利用异常处理打印相应信息   
DECLARE   
    salary emp.sal%TYPE;   
BEGIN   
    SELECT sal INTO salary FROM emp WHERE empno='7788';   
    IF salary < 3000 THEN   
        UPDATE emp SET sal = '3000' WHERE empno = '7788';   
        DBMS_OUTPUT.PUT_LINE('记录已更新');   
    ELSE   
        DBMS_OUTPUT.PUT_LINE('IF 条件不成立');   
    END IF;   
EXCEPTION   
    WHEN NO_DATA_FOUND THEN   
        DBMS_OUTPUT.PUT_LINE('7788雇员不存在');   
    WHEN OTHERS THEN   
        DBMS_OUTPUT.PUT_LINE('Unknown Error');   
END;   
/   
  
--用户自定义异常---------------------------------------------------//   
--001  
DECLARE   
    --v_num1 NUMBER:=5;   
    v_num1 NUMBER:=0;   
    --v_num2 NUMBER:=0;   
    v_num2 NUMBER:=5;   
    MyException EXCEPTION;   
BEGIN   
    DBMS_OUTPUT.PUT_LINE(v_num1/v_num2);       
        RAISE MyException;  --引发自定义异常   
       
    DBMS_OUTPUT.PUT_LINE('OK');  --此句永远不会执行,因为发生异常后程序将直接跳到EXCEPTION段   
EXCEPTION   
    WHEN MyException THEN   
        DBMS_OUTPUT.PUT_LINE('Cannot Divide Zero');   
    --WHEN ZERO_DIVIDE THEN   
    --  DBMS_OUTPUT.PUT_LINE('Can not Divide Zero');   
    WHEN OTHERS THEN   
        DBMS_OUTPUT.PUT_LINE('Unknown Error');   
END;   
/   
--002  
DECLARE   
    id score.id%TYPE;   
    java score.java%TYPE;   
    MyException EXCEPTION;   
BEGIN   
    SELECT id,java INTO id,java FROM score WHERE id = 4;   
    IF java < 0 OR java > 100 THEN   
        RAISE MyException;   
    ELSE   
        DBMS_OUTPUT.PUT_LINE('OK');   
    END IF;   
  
EXCEPTION   
    WHEN MyException THEN   
        UPDA