设为首页 收藏本站
查看: 884|回复: 0

[经验分享] (DB2)Handler基本语义与定义

[复制链接]

尚未签到

发表于 2016-11-15 09:26:03 | 显示全部楼层 |阅读模式
  DB2 条件处理器定义(Condition Handler Declarations)
  
可以在SQL procedure中定义一个条件处理器(Handler)来处理特殊的行为。下面是一个通用的处理器(Handler)定义格式:
  
DECLARE handler-type HANDLER FOR conditionSQL-procedure-statement
  
当DB2触发一个满足定义的条件时,就会将控制权交给条件处理器(Condition handler),条件处理器根据指定的处理类型(Handle Type)来执行指定的SQL-Procedure-Statement。
  
处理类型(Handler-types)
  
CONTINUE 执行SQL-procedure-statement的过程中如果出现错误,则跳到引起错误sql statement后的语句继续执行。
  
EXIT 执行SQL-procedure-statement的过程中如果出现错误,直接跳到定义该condition的语句块(compound statement,类似oracle PL/SQL block)之后的语句。
  
UNDO 在执行SQL-procedure-statement之前定义,如果在定义该handler的语句块(compound statement)内发生错误,DB2将rollback所有执行的SQL statement.
  
Note: UNDO处理器(handler)只能定义在ATOMIC的语句块(compound statements)中。ATOMIC的含义:如果在语句块(compound statement)中一条语句出现了错误,该语句块(compound statement)中所有的语句将被rollback.NOT ATOMIC含义相反。
  
处理条件(Conditions)
  
DB2预定义了3中处理条件(Condition):NOT FOUND SQLCODE等于于正100(+100)或者SQLSTATE以‘02’开头的所有错误(Condition)。
  
SQLEXCEPTION SQLCODE为负数的所有错误(Condition)。
  
SQLWARNING 所有的警告类型的错误(Condition)(SQLWARNO等于‘W’),或者一个正SQL(positiveSQL)的SQLCODE不同于正100(+100)(这句话翻译有点confused,引用原文:or that results in a positive SQL return code other than +100).这种类型的SQLSTATE都以’01’开头。
  DB2支持通过DECLARE为一个特定的SQLSTATE定义自定义的条件(condition)。
  
SQL-procedure-statement
  
条件处理器(condition handler)的行为语句可以是单SQL(Single SQL)的SQL Statement,也可以是用BEGIN..END来定义一个语句块(compound statement).如果你是通过语句块来定义条件处理器(condition hander)的行为时,那么你必须首先定义2个本地变量(local variable)或者参数来接收SQLCODE和SQLSTATE。如果你没有将SQLSTATE或SQLCODE指定给本地的变量或者参数的话,调用该条件处理器的SQLCODE和SQLSTATE值将丢失。
  
以下是一些条件处理器的Samples:
  
CONTINUE handler 当DB2触发一个NOT FOUND错误(condition)时,以下的处理器(handler)将1赋给本地变量at_end.并且将控制权交给引起NOT FOUND错误语句的下一条语句,继续执行。
  
DECLARE CONTINUE HANDLER FOR NOT FOUND SET at_end = 1;
  
EXIT handler 在这个例子中,退出处理器(Exit Handler)的生效范围被限制在Label A限定的语句块(compound statement)中。如果表JAVELIN不存在,“DROP TABLE JAVELIN”将触发NO_TABLE错误(Condition), 退出处理器(Exit Handler)被激活,变量OUT_BUFFER被置值为“Table does not exist”,程序跳到C处的insert statement继续执行,忽略Label A限定的语句块(compound statement)中的其他语句。如果DROP statement能都执行成功,退出处理器(Exit Handler)将不被激活,执行将逐句执行下去,包括Label B限定的语句。
  CREATE PROCEDURE EXIT_TEST ()
LANGUAGE SQL
BEGIN
   DECLARE OUT_BUFFER VARCHAR(80);
   DECLARE NO_TABLE CONDITION FOR SQLSTATE '42704';
   A: BEGIN
      DECLARE EXIT HANDLER FOR NO_TABLE
      BEGIN
        SET OUT_BUFFER='Table does not exist';
      END;
  -- Drop potentially nonexistent table:
   DROP TABLE JAVELIN;
   B: SET OUT_BUFFER='Table dropped successfully'; END;
  -- Copy OUT_BUFFER to some message table:
   C: INSERT INTO MESSAGES VALUES OUT_BUFFER;
END
  UNDO handler 本例中,撤销处理器(undo handler)的生效范围被限定在Label A限定的语句块(compound statement)中。如果表JAVELIN不存在,DROP语句将触发NO_TABLE错误(condition),撤销处理器(undo handler)被激活,DROP语句之前的insert将被回滚,同时OUT_BUFFER被置值为“Table does not exist”,执行调转到Label C限定的insert语句,Label A限定的其他语句将被忽略。如果DROP语句能够执行成功,撤销处理器(undo handler)不会被激活,执行将逐句执行下去,包括B限定的语句。
  
CREATE PROCEDURE UNDO_TEST () LANGUAGE SQL BEGIN DECLARE OUT_BUFFER VARCHAR(80); DECLARE NO_TABLE CONDITION FOR SQLSTATE '42704';
  
A: BEGIN ATOMIC DECLARE UNDO HANDLER FOR NO_TABLE BEGIN SET OUT_BUFFER='Table does not exist'; END;
  
INSERT INTO MESSAGES VALUES 'This message will be removed by a rollback.';
  
-- Drop potentially nonexistent table: DROP TABLE JAVELIN;
  B: SET OUT_BUFFER='Table dropped successfully'; END;
  -- Copy OUT_BUFFER to some message table: C: INSERT INTO MESSAGES VALUES OUT_BUFFER; END
  
Note:
撤销处理器(undo handler)只能被定义在ATOMIC语句块中。ATOMIC的含义:如果在语句块(compound statement)中一条语句出现了错误,该语句块(compound statement)中所有的语句将被rollback.NOT ATOMIC含义相反。
  
说明:本文是根据IBM DB2 Application Development Guide翻译而来。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-300585-1-1.html 上篇帖子: DB2 V9.7分区索引新特性 下篇帖子: Db2数据库v8.1 升级到 FP6c
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表