广告
返回顶部
首页 > 资讯 > 数据库 >2011-10-21 自定义异常的捕获
  • 206
分享到

2011-10-21 自定义异常的捕获

2024-04-02 19:04:59 206人浏览 薄情痞子
摘要

Http://www.itpub.net/thread-1499223-7-1.html 70楼   下列的哪些程序块在执行之后会显示:"Trapped!"   注

Http://www.itpub.net/thread-1499223-7-1.html

70楼

 

下列的哪些程序块在执行之后会显示:"Trapped!"
 
注意:当你试图把字符串 "13-DEC-2004 6:56 PM" 使用掩码 "DD-MON-YYYY HH:MI:SS" 转换成日期型时,oracle 会抛出 ORA-01858 错误。

 

(A)

DECLARE
   e1   EXCEPTioN;
   PRAGMA EXCEPTION_INIT (e1, -1858);
BEGIN
   DBMS_OUTPUT.put_line (
      TO_DATE ('13-DEC-2004 6:56 PM'
             ,  'DD-MON-YYYY HH:MI:SS'));
EXCEPTION
   WHEN e1
   THEN
      DBMS_OUTPUT.put_line ('Trapped!');
END;
/
sql> DECLARE
  2     e1   EXCEPTION;
  3     PRAGMA EXCEPTION_INIT (e1, -1858);
  4  BEGIN
  5     DBMS_OUTPUT.put_line (
  6        TO_DATE ('13-DEC-2004 6:56 PM'
  7               ,  'DD-MON-YYYY HH:MI:SS'));
  8  EXCEPTION
  9     WHEN e1
 10     THEN
 11        DBMS_OUTPUT.put_line ('Trapped!');
 12  END;
 13  /
DECLARE
   e1   EXCEPTION;
   PRAGMA EXCEPTION_INIT (e1, -1858);
BEGIN
   DBMS_OUTPUT.put_line (
      TO_DATE ('13-DEC-2004 6:56 PM'
             ,  'DD-MON-YYYY HH:MI:SS'));
EXCEPTION
   WHEN e1
   THEN
      DBMS_OUTPUT.put_line ('Trapped!');
END;
ORA-01843: 无效的月份
ORA-06512: 在 line 5
SQL>

 

(B)

DECLARE
   e1   EXCEPTION;
   PRAGMA EXCEPTION_INIT (e1, -1858);
BEGIN
   DECLARE
      e2   EXCEPTION;
      PRAGMA EXCEPTION_INIT (e2, -1858);
   BEGIN
      DBMS_OUTPUT.put_line (
         TO_DATE ('13-DEC-2004 6:56 PM'
                ,  'DD-MON-YYYY HH:MI:SS'));
   END;
EXCEPTION
   WHEN e1
   THEN
      DBMS_OUTPUT.put_line ('Trapped!');
END;
/
SQL> DECLARE
  2     e1   EXCEPTION;
  3     PRAGMA EXCEPTION_INIT (e1, -1858);
  4  BEGIN
  5     DECLARE
  6        e2   EXCEPTION;
  7        PRAGMA EXCEPTION_INIT (e2, -1858);
  8     BEGIN
  9        DBMS_OUTPUT.put_line (
 10           TO_DATE ('13-DEC-2004 6:56 PM'
 11                  ,  'DD-MON-YYYY HH:MI:SS'));
 12     END;
 13  EXCEPTION
 14     WHEN e1
 15     THEN
 16        DBMS_OUTPUT.put_line ('Trapped!');
 17  END;
 18  /
DECLARE
   e1   EXCEPTION;
   PRAGMA EXCEPTION_INIT (e1, -1858);
BEGIN
   DECLARE
      e2   EXCEPTION;
      PRAGMA EXCEPTION_INIT (e2, -1858);
   BEGIN
      DBMS_OUTPUT.put_line (
         TO_DATE ('13-DEC-2004 6:56 PM'
                ,  'DD-MON-YYYY HH:MI:SS'));
   END;
EXCEPTION
   WHEN e1
   THEN
      DBMS_OUTPUT.put_line ('Trapped!');
END;
ORA-01843: 无效的月份
ORA-06512: 在 line 9
SQL>

 

(C)

DECLARE
   e1   EXCEPTION;
   PRAGMA EXCEPTION_INIT (e1, -1858);
BEGIN
   DECLARE
      e2   EXCEPTION;
      PRAGMA EXCEPTION_INIT (e2, -1858);
   BEGIN
      DBMS_OUTPUT.put_line (
         TO_DATE ('13-DEC-2004 6:56 PM'
                ,  'DD-MON-YYYY HH:MI:SS'));
   END;
EXCEPTION
   WHEN e2
   THEN
      DBMS_OUTPUT.put_line ('Trapped!');
END;
/
SQL> DECLARE
  2     e1   EXCEPTION;
  3     PRAGMA EXCEPTION_INIT (e1, -1858);
  4  BEGIN
  5     DECLARE
  6        e2   EXCEPTION;
  7        PRAGMA EXCEPTION_INIT (e2, -1858);
  8     BEGIN
  9        DBMS_OUTPUT.put_line (
 10           TO_DATE ('13-DEC-2004 6:56 PM'
 11                  ,  'DD-MON-YYYY HH:MI:SS'));
 12     END;
 13  EXCEPTION
 14     WHEN e2
 15     THEN
 16        DBMS_OUTPUT.put_line ('Trapped!');
 17  END;
 18  /
DECLARE
   e1   EXCEPTION;
   PRAGMA EXCEPTION_INIT (e1, -1858);
BEGIN
   DECLARE
      e2   EXCEPTION;
      PRAGMA EXCEPTION_INIT (e2, -1858);
   BEGIN
      DBMS_OUTPUT.put_line (
         TO_DATE ('13-DEC-2004 6:56 PM'
                ,  'DD-MON-YYYY HH:MI:SS'));
   END;
EXCEPTION
   WHEN e2
   THEN
      DBMS_OUTPUT.put_line ('Trapped!');
END;
ORA-06550: 第 14 行, 第 9 列: 
PLS-00201: 必须声明标识符 'E2'
ORA-06550: 第 0 行, 第 0 列: 
PL/SQL: Compilation unit analysis terminated
SQL>

 

(D)

DECLARE
   e1   EXCEPTION;
BEGIN
   DECLARE
      PRAGMA EXCEPTION_INIT (e1, -1858);
   BEGIN
      DBMS_OUTPUT.put_line (
         TO_DATE ('13-DEC-2004 6:56 PM'
                ,  'DD-MON-YYYY HH:MI:SS'));
   END;
EXCEPTION
   WHEN e1
   THEN
      DBMS_OUTPUT.put_line ('Trapped!');
END;
/
SQL> DECLARE
  2     e1   EXCEPTION;
  3  BEGIN
  4     DECLARE
  5        PRAGMA EXCEPTION_INIT (e1, -1858);
  6     BEGIN
  7        DBMS_OUTPUT.put_line (
  8           TO_DATE ('13-DEC-2004 6:56 PM'
  9                  ,  'DD-MON-YYYY HH:MI:SS'));
 10     END;
 11  EXCEPTION
 12     WHEN e1
 13     THEN
 14        DBMS_OUTPUT.put_line ('Trapped!');
 15  END;
 16  /
DECLARE
   e1   EXCEPTION;
BEGIN
   DECLARE
      PRAGMA EXCEPTION_INIT (e1, -1858);
   BEGIN
      DBMS_OUTPUT.put_line (
         TO_DATE ('13-DEC-2004 6:56 PM'
                ,  'DD-MON-YYYY HH:MI:SS'));
   END;
EXCEPTION
   WHEN e1
   THEN
      DBMS_OUTPUT.put_line ('Trapped!');
END;
ORA-06550: 第 2 行, 第 4 列: 
PLS-00700: 'E1' 的 PRAGMA EXCEPTION_INIT 必须在同一个声明部分中的异常错误声明之后
ORA-06550: 第 5 行, 第 7 列: 
PL/SQL: Item ignored
SQL>

 

结果有出入,设置语言为英文后重跑

SQL> alter session set nls_language='american';
Session altered
SQL> 
SQL> DECLARE
  2     e1   EXCEPTION;
  3     PRAGMA EXCEPTION_INIT (e1, -1858);
  4  BEGIN
  5     DBMS_OUTPUT.put_line (
  6        TO_DATE ('13-DEC-2004 6:56 PM'
  7               ,  'DD-MON-YYYY HH:MI:SS'));
  8  EXCEPTION
  9     WHEN e1
 10     THEN
 11        DBMS_OUTPUT.put_line ('Trapped!');
 12  END;
 13  /
Trapped!
PL/SQL procedure successfully completed
SQL>
SQL> alter session set nls_language='american';
Session altered
SQL> 
SQL> 
SQL> DECLARE
  2     e1   EXCEPTION;
  3     PRAGMA EXCEPTION_INIT (e1, -1858);
  4  BEGIN
  5     DECLARE
  6        e2   EXCEPTION;
  7        PRAGMA EXCEPTION_INIT (e2, -1858);
  8     BEGIN
  9        DBMS_OUTPUT.put_line (
 10           TO_DATE ('13-DEC-2004 6:56 PM'
 11                  ,  'DD-MON-YYYY HH:MI:SS'));
 12     END;
 13  EXCEPTION
 14     WHEN e1
 15     THEN
 16        DBMS_OUTPUT.put_line ('Trapped!');
 17  END;
 18  /
Trapped!
PL/SQL procedure successfully completed
SQL>
SQL> alter session set nls_language='american';
Session altered
SQL> 
SQL> 
SQL> DECLARE
  2     e1   EXCEPTION;
  3     PRAGMA EXCEPTION_INIT (e1, -1858);
  4  BEGIN
  5     DECLARE
  6        e2   EXCEPTION;
  7        PRAGMA EXCEPTION_INIT (e2, -1858);
  8     BEGIN
  9        DBMS_OUTPUT.put_line (
 10           TO_DATE ('13-DEC-2004 6:56 PM'
 11                  ,  'DD-MON-YYYY HH:MI:SS'));
 12     END;
 13  EXCEPTION
 14     WHEN e2
 15     THEN
 16        DBMS_OUTPUT.put_line ('Trapped!');
 17  END;
 18  /
DECLARE
   e1   EXCEPTION;
   PRAGMA EXCEPTION_INIT (e1, -1858);
BEGIN
   DECLARE
      e2   EXCEPTION;
      PRAGMA EXCEPTION_INIT (e2, -1858);
   BEGIN
      DBMS_OUTPUT.put_line (
         TO_DATE ('13-DEC-2004 6:56 PM'
                ,  'DD-MON-YYYY HH:MI:SS'));
   END;
EXCEPTION
   WHEN e2
   THEN
      DBMS_OUTPUT.put_line ('Trapped!');
END;
ORA-06550: line 14, column 9:
PLS-00201: identifier 'E2' must be declared
ORA-06550: line 0, column 0:
PL/SQL: Compilation unit analysis terminated
SQL>
SQL> alter session set nls_language='american';
Session altered
SQL> 
SQL> 
SQL> DECLARE
  2     e1   EXCEPTION;
  3  BEGIN
  4     DECLARE
  5        PRAGMA EXCEPTION_INIT (e1, -1858);
  6     BEGIN
  7        DBMS_OUTPUT.put_line (
  8           TO_DATE ('13-DEC-2004 6:56 PM'
  9                  ,  'DD-MON-YYYY HH:MI:SS'));
 10     END;
 11  EXCEPTION
 12     WHEN e1
 13     THEN
 14        DBMS_OUTPUT.put_line ('Trapped!');
 15  END;
 16  /
DECLARE
   e1   EXCEPTION;
BEGIN
   DECLARE
      PRAGMA EXCEPTION_INIT (e1, -1858);
   BEGIN
      DBMS_OUTPUT.put_line (
         TO_DATE ('13-DEC-2004 6:56 PM'
                ,  'DD-MON-YYYY HH:MI:SS'));
   END;
EXCEPTION
   WHEN e1
   THEN
      DBMS_OUTPUT.put_line ('Trapped!');
END;
ORA-06550: line 2, column 4:
PLS-00700: PRAGMA EXCEPTION_INIT of E1 must follow declaration of its exception in the same declarative part
ORA-06550: line 5, column 7:
PL/SQL: Item ignored
SQL>

 

答案AB(设置语言为英文,则答案AB;如语言为中文,答案均不正确)

答案说明74楼

A: 正确捕获-1858异常
B: 内层也定义了-1858但是没有捕获,所以外层仍然能够捕获到
C: 内层的定义在外层是不可见的,会报PLS-00201: identifier 'E2' must be declared
D: PRAGMA EXCEPTION_INIT必须和EXCEPTION定义在同一层DECLARE中: PLS-00700: PRAGMA EXCEPTION_INIT of E1 must follow declaration of its exception in the same declarative part
您可能感兴趣的文档:

--结束END--

本文标题: 2011-10-21 自定义异常的捕获

本文链接: https://www.lsjlt.com/news/46714.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 2011-10-21 自定义异常的捕获
    http://www.itpub.net/thread-1499223-7-1.html 70楼   下列的哪些程序块在执行之后会显示:"Trapped!"   注...
    99+
    2022-10-18
  • 2011-11-21 未捕获异常
    http://www.itpub.net/thread-1499223-17-1.html 167楼 下列哪些选项在执行之后会导致未捕获的异常: ORA-06502: PL/SQL:&nb...
    99+
    2022-10-18
  • Java中的自定义异常捕获方式
    目录Java 自定义异常捕获自定义异常类格式如下:自定义异常类的调用格式如下:可能出现异常的代码写法如下:本题完整代码如下:自定义异常Exception根据业务需要不用的异常打印不用类型的日志Java 自定义异常捕获 编写一个程序,将字符串...
    99+
    2016-05-06
    Java异常 自定义异常 异常捕获
  • 自定义注解和springAOP捕获Service层异常,并处理自定义异常操作
    一 自定义异常 public class NoParamsException extends Exception { //用详细信息指定一个异常 public ...
    99+
    2022-11-12
  • springboot如何自定义异常并捕获异常返给前端
    小编给大家分享一下springboot如何自定义异常并捕获异常返给前端,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!背景在开发中,如果用try catch的方式,...
    99+
    2023-06-25
  • 自定义注解和springAOP捕获Service层异常并处理自定义异常的示例分析
    这篇文章主要为大家展示了“自定义注解和springAOP捕获Service层异常并处理自定义异常的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“自定义注解和springAOP捕获Serv...
    99+
    2023-06-15
  • springboot 自定义异常并捕获异常返给前端的实现代码
    背景 在开发中,如果用try catch的方式,每个方法都需要单独实现,为了方便分类异常,返回给前端,采用了@ControllerAdvice注解和继承了RuntimeExcepti...
    99+
    2022-11-12
  • 详解Spring Security 捕获 filter 层面异常返回我们自定义的内容
    通常,我们通过 @ControllerAdvice 和 @ExceptionHandler 来捕获并处理 Controller 层面的异常。但是,filter 是在 controll...
    99+
    2022-11-13
  • JavaSpringMVC的自定义异常类
    目录1. 异常处理的思路2. 自定义异常处理器3. web的处理异常机制总结1. 异常处理的思路 在java中,对于异常的处理一般有两种方式: 一种在当前方法捕获处理(try-cat...
    99+
    2022-11-13
  • SpringBoot Security的自定义异常处理
    目录SpringBoot Security自定义异常access_denied 方面异常Invalid access token 方面异常Bad credentials 方面异常(登...
    99+
    2022-11-12
  • Java自定义异常与异常使用的最佳方式
    目录异常的分类1. 非运行时异常(Checked Exception)2. 运行时异常(Runtime Exception/Unchecked Exception)异常的处理一、对应非运行时异常,必须对其进行处理二、对于运行时异常,可以不对...
    99+
    2019-09-12
    Java异常 自定义异常 异常使用
  • Java自定义异常的方法是什么
    本文小编为大家详细介绍“Java自定义异常的方法是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“Java自定义异常的方法是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、异常分为哪几种异常分为两种,分...
    99+
    2023-07-06
  • python用户自定义异常的示例分析
    这篇文章主要介绍了python用户自定义异常的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。说明程序可以通过创建一个新的异常类来命名它们自己的异常。异常应该是典型的继...
    99+
    2023-06-20
  • python用户自定义异常的实例讲解
    说明 程序可以通过创建一个新的异常类来命名它们自己的异常。异常应该是典型的继承自Exception类,直接或间接的方式。 异常python有一个大基类,继承了Exception。因此,我们的定制类也必须继承Excep...
    99+
    2022-06-02
    python 自定义 异常
  • Java中的异常类怎么实现自定义
    Java中的异常类怎么实现自定义?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Java自定义异常类的实例详解为什么要自己编写异常类?假如jdk里面没有提供的异常...
    99+
    2023-05-31
    java ava
  • dubbo自定义异常的完整步骤与测试
    目录前言操作步骤一、创建一个公共的用于处理异常的工程二、生产端配置文件改造 三、消费端配置测试1、启动本地的zk服务2、启动生产端服务3、启动消费端服务模拟服务调用使用场景...
    99+
    2022-11-13
  • 详解在Python程序中自定义异常的方法
    通过创建一个新的异常类,程序可以命名它们自己的异常。异常应该是典型的继承自Exception类,通过直接或间接的方式。 以下为与RuntimeError相关的实例,实例中创建了一个类,基类为RuntimeE...
    99+
    2022-06-04
    自定义 详解 异常
  • springboot集成shiro遭遇自定义filter异常的解决
    目录springboot集成shiro遭遇自定义filter异常1、用maven添加shiro2、配置shiro3、实现自定义的Realm、filter、SubjectFactory...
    99+
    2022-11-12
  • SpringMVC异常处理机制与自定义异常处理方式的示例分析
    这篇文章主要介绍SpringMVC异常处理机制与自定义异常处理方式的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!提到异常处理,就不得不提HandlerExceptionResolvers,我们的Dispat...
    99+
    2023-06-25
  • Spring Cloud Gateway自定义异常处理Exception Handler的方法小结
    版本: Spring Cloud 2020.0.3 常见的方法有 实现自己的 DefaultErrorWebExceptionHandler 或 仅实现ErrorAttributes...
    99+
    2022-11-12
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作