文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2024-04-02 19:55

关注

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
阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯