`
FengShen_Xia
  • 浏览: 279335 次
  • 性别: Icon_minigender_1
  • 来自: 东方水城
社区版块
存档分类
最新评论

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   
        UPDATE score SET java=0 WHERE id = 4;   
        DBMS_OUTPUT.PUT_LINE('分数不能大于100或小于0,现已经清0');   
    WHEN OTHERS THEN   
        DBMS_OUTPUT.PUT_LINE('Unknown Error');   
END;   
/   
--003  
DECLARE   
    v_date emp.hiredate%TYPE;   
    MyException EXCEPTION;   
BEGIN   
    INSERT INTO emp(empno,hiredate)   
        VALUES(1111,TO_DATE('2010-12-25','yyyy-mm-dd'));   
    COMMIT;   
    SELECT hiredate INTO v_date FROM emp WHERE empno=1111;   
    IF v_date > SYSDATE THEN   
        RAISE MyException;   
    END IF;   
    DBMS_OUTPUT.PUT_LINE('执行完毕');   
EXCEPTION   
    WHEN MyException THEN   
        DBMS_OUTPUT.PUT_LINE('雇用日期不能大于当前日期');   
        --raise_application_error(-20002,'雇用日期不能大于当前日期');   
        UPDATE emp SET hiredate = SYSDATE WHERE empno = 1111;   
        DBMS_OUTPUT.PUT_LINE('日期已更新为当前日期');   
    WHEN OTHERS THEN   
        DBMS_OUTPUT.PUT_LINE('Unknown Error');   
END;   
/   
  
--将定义好的异常与标准的ORACLE错误联系起来-------------------------//   
--001  
DECLARE   
    MyException EXCEPTION;   
    PRAGMA EXCEPTION_INIT(MyException,-00001);  --关联语句   
BEGIN   
    INSERT INTO emp(empno) VALUES(1234);  --发生异常,企图插入有Check约束的重复值   
    COMMIT;  --插入后提交   
    DBMS_OUTPUT.PUT_LINE('插入正常');   
EXCEPTION   
    WHEN MyException THEN   
        DBMS_OUTPUT.PUT_LINE('ORA-00001: 违反了唯一约束');   
    WHEN OTHERS THEN   
        DBMS_OUTPUT.PUT_LINE('Unknown Error');   
END;   
/   
--002  
CREATE TABLE a   
(   
    id INT NOT NULL,   
    name VARCHAR2(20) NOT NULL   
);   
DECLARE   
    MyException EXCEPTION;   
    PRAGMA EXCEPTION_INIT(MyException,-1400);  --关联语句   
BEGIN   
    INSERT INTO a(id) VALUES(1);  --发生异常,违反了NOT NULL约束   
EXCEPTION   
    WHEN MyException THEN   
        DBMS_OUTPUT.PUT_LINE('错误代号:-1400');   
        DBMS_OUTPUT.PUT_LINE('错误描述:违反了NOT NULL约束');   
        DBMS_OUTPUT.PUT_LINE('错误发生时间:' ||    
                    TO_CHAR(SYSDATE,'yyyy-mm-dd hh24:mi:ss'));   
        INSERT INTO errinfo    
          VALUES('-1400','违反了 NOT NULL约束',TO_CHAR(SYSDATE,'yyyy-mm-dd hh24:mi:ss'));   
        DBMS_OUTPUT.PUT_LINE('已经将错误记录在ErrInfo表');   
    WHEN OTHERS THEN   
        DBMS_OUTPUT.PUT_LINE('Unknown Error');   
END;   
/   
--003  
DECLARE   
    MyException EXCEPTION;   
    salary emp.sal%TYPE;   
BEGIN   
    SELECT sal INTO salary FROM emp WHERE empno = '7788';   
    IF salary > 2000 THEN   
        RAISE MyException;   
    END IF;   
EXCEPTION   
    WHEN MyException THEN   
        RAISE_APPLICATION_ERROR(-20001,'RAISE_APPLICATION_ERROR异常发生',FALSE); --TRUE   
    WHEN OTHERS THEN   
        DBMS_OUTPUT.PUT_LINE('Unknown Error');   
END;   
/   
--课后练习---------------------------------------------------------//   
--001  
DECLARE   
    gz emp.sal%TYPE;   
    MyExc EXCEPTION;   
BEGIN   
    SELECT sal INTO gz FROM emp WHERE ename='SCOTT';   
    DBMS_OUTPUT.PUT_LINE('原工资 : ' || gz);   
    IF gz < 2000 THEN   
        RAISE MyExc;   
    ELSE   
        DBMS_OUTPUT.PUT_LINE('工资无需更新');   
    END IF;   
EXCEPTION   
    WHEN MyExc THEN   
        UPDATE emp SET sal = 3000 WHERE ename='SCOTT';   
        DBMS_OUTPUT.PUT_LINE('记录已经更新');   
        SELECT sal INTO gz FROM emp WHERE ename='SCOTT';   
        DBMS_OUTPUT.PUT_LINE('更新后工资 : ' || gz);   
    WHEN OTHERS THEN   
        DBMS_OUTPUT.PUT_LINE('Unknown Error');   
END;   
/   
--002  
DECLARE   
    lo salgrade.losal%TYPE;   
    hi salgrade.hisal%TYPE;   
    MyExc EXCEPTION;   
BEGIN   
    INSERT INTO salgrade VALUES(6,2600,2400);   
    COMMIT;   
    SELECT losal,hisal INTO lo,hi FROM salgrade WHERE grade = 6;   
    IF lo > hi THEN   
        RAISE MyExc;   
    ELSE   
        DBMS_OUTPUT.PUT_LINE('记录已经插入');   
    END IF;   
EXCEPTION   
    WHEN MyExc THEN   
        --删除插入的记录并打印相应信息   
        delete salgrade WHERE grade = 6;   
        DBMS_OUTPUT.PUT_LINE('记录插入失败 LOSAL 必须小于 HISAL');   
    WHEN OTHERS THEN   
        DBMS_OUTPUT.PUT_LINE('Unknown Error');   
END;   
/   
  
--附注-------------------------------------------------------------//   
--如需在PL\SQL中进行值输入,   
DECLARE   
  num LONG;   
BEGIN   
  num := '&num';   
  DBMS_OUTPUT.PUT_LINE('Input value is : ' || num);   
END;   
/   
--注意:如果要使你在DBMS_OUTPUT.PUT_LINE(...)中显示的语句得以显示,则必须显示的调用   
SET SERVEROUTPUT ON;   
----------------------------------------------------------------------------------End//  
 

 

本文来自:http://javato.iteye.com/blog/78060

 

 

分享到:
评论

相关推荐

    ORACLE异常处理剖析.pdf

    Oracle异常处理是数据库管理和应用程序开发中的关键环节,它涉及到对程序执行过程中可能出现的错误和异常情况进行有效管理和响应。Oracle数据库,作为一款广泛使用的商业关系型数据库管理系统,提供了强大的异常处理...

    oracle 异常处理剖析共.pdf

    总结来说,Oracle异常处理是通过预定义和自定义异常来实现的,它增强了程序对错误的响应能力,帮助开发者在遇到问题时能够有序地处理,避免程序崩溃,保证系统的正常运行。理解并熟练掌握Oracle的异常处理机制,对于...

    oracle异常处理

    Oracle 异常处理是 PL/SQL 编程中不可或缺的一部分,它允许开发者优雅地处理程序运行时遇到的各种错误。在 PL/SQL 中,异常处理主要分为预定义异常、非预定义异常以及自定义异常。 预定义异常是 Oracle 为常见错误...

    ORACLE 异常处理总结.doc

    Oracle 异常处理是PL/SQL编程中的关键组成部分,它允许开发者优雅地处理程序执行过程中可能出现的错误,确保系统的稳定性和可靠性。异常处理是通过异常情况(EXCEPTION)和异常处理器(EXCEPTION HANDLER)来实现的...

    oracle异常处理归纳.docx

    ### Oracle异常处理归纳 本文将基于提供的文档信息对Oracle中常见的异常问题进行归纳总结,并提供相应的解决方案。这些异常包括但不限于`ORA-12651:TNS:没有监听器`、`ORA-12545:因目标主机和对象不存在,连接失败`...

    Oracle 异常处理

    Oracle异常处理基于PL/SQL(Procedural Language/Structured Query Language),这是一种扩展SQL,允许开发者编写带有流程控制、循环、条件判断等结构化编程元素的存储过程。在PL/SQL中,异常是程序运行时发生的问题...

    oracle异常处理课后答案

    这个是oracle课成异常处理章节后面的部分习题答案,大概四五道题的答案。

    oracle笔记异常处理

    oracle笔记异常处理,异常处理的代码案例和知识点笔记!

    oracle自定义异常

    #### 一、Oracle异常处理机制简介 在Oracle PL/SQL编程中,异常处理是一项非常重要的功能。它可以帮助开发者捕获并处理程序运行时可能发生的错误情况,确保应用程序能够稳定可靠地运行。Oracle PL/SQL支持多种类型...

    ORACLE 异常错误处理

    根据ORACLE提供的异常处理机制,我们可以将异常分为三类: 1. **预定义异常**:这是由ORACLE系统预先定义好的一组异常,当特定的错误发生时,系统会自动抛出相应的异常。例如,在尝试插入一条已经存在的记录到具有...

    自己总结的oracle常见异常处理步骤

    oracle异常处理步骤自己总结的,不太成熟,大家可以不看,只是我的备忘录

    ch03 oracle异常异常与动态sql

    本章我们将深入探讨“Oracle异常处理”以及“动态SQL”的相关知识点。 异常处理是编程中的一个关键环节,尤其是在Oracle数据库环境中。Oracle提供了完善的异常处理机制,使得开发人员能够优雅地捕获并处理错误,...

    Oracle 存储过程异常处理.docx

    Oracle 存储过程异常处理 Oracle 存储过程异常处理是指在 Oracle 数据库中使用存储过程时出现的异常情况的处理方法。异常处理是指在程序执行过程中出现错误或异常时,采取相应的处理措施,以确保程序的可靠性和...

    oracle异常总结

    Oracle 异常处理是 PL/SQL 编程中不可或缺的一部分,它允许开发者优雅地处理运行时错误,确保程序的稳定性和可维护性。在Oracle数据库中,异常分为预定义异常、非预定义异常和自定义异常。 预定义异常是Oracle为...

    oracle异常及触发器.pptx

    总之,Oracle异常处理和触发器是数据库管理的重要工具,它们可以帮助开发者优雅地处理错误,保持数据一致性,并在后台实现复杂业务逻辑。理解并熟练运用这两者,对于构建高效、稳定的数据库应用程序至关重要。

    oracle例外处理

    ### Oracle异常处理详解 在Oracle数据库的PL/SQL编程中,异常处理是非常重要的一个环节,它可以帮助我们更好地控制程序流程,提高程序的健壮性和稳定性。本文将详细解析Oracle PL/SQL中的各种异常类型及其应用场景...

    Oracle_存储过程exception异常处理大全及实例经典最终.docx

    Oracle 存储过程 exception 异常处理大全及实例经典最终 Oracle 存储过程 exception 异常处理大全及实例经典最终是 Oracle 数据库中存储过程的异常处理机制。异常处理是指在程序执行过程中出现的错误或未预料到的...

    Oracle Exception汇总(自定义Oracle异常)

    下面,我们将深入探讨一些常见的Oracle异常及其解决策略。 1. **NO_DATA_FOUND** (ORA-01403): 当执行`SELECT INTO`语句时,如果没有返回任何数据,系统会抛出此异常。为了避免程序中断,可以使用`EXCEPTION WHEN ...

    ORACLE游标与异常处理

    在Oracle数据库中,游标(Cursor)和异常处理(Exception Handling)是PL/SQL编程的重要组成部分,它们在处理复杂逻辑和确保数据完整性方面起到关键作用。以下是对这两个主题的详细阐述。 首先,让我们来理解Oracle...

Global site tag (gtag.js) - Google Analytics