日期:2014-05-16 浏览次数:20794 次
--异常处理---------------------//
--预定义异常
--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