教您如何使用DB2条件处理器处理存储过程运行中的SQL错误

数据库
DB2条件处理器用于处理存储过程运行过程中的SQL错误、SQL警告等。下文对它的用法作了详尽的阐述,供您参考学习之用。

DB2条件处理器对于存储过程来说,有着不可替代的作用。在DB2中,SQL存储过程可以利用DB2条件处理器(Condition Handler)来处理存储过程运行过程中的SQL错误(SQLERROR)、SQL警告(SQLWARNING)和没有数据(NOT FOUND)三种常见情况以及你自己定义的触发条件,你可以使用包括退出(EXIT)、继续(CONTINUE)和撤销(UNDO)在内的三种条件处理器。

在SQL存储过程运行过程中,如果出现了SQLERROR、SQLWARNING和NOT FOUND三种情况,SQL存储过程将会自动将执行SQL语句后的SQLCODE和SQLSTATE存储在你事先定义好的变量SQLCODE和SQLSTATE中,并触发你在存储过程中定义的条件处理器。

在SQL存储过程处理错误,您需要做如下两步:声明SQLCODE和SQLSTATE变量、定义条件处理器。在SQL存储过程中,您通过下列语句声明SQLCODE和SQLSTATE变量:
DECLARE SQLCODE INTEGER DEFAULT 0;
DECLARE SQLSTATE CHAR(5) DEFAULT '00000';

当存储过程执行时,DB2会自动将该SQL语句的返回码付给这两个变量,你可以在调试程序的时候,将这两个值插入到调试表中,或者利用条件处理器将这两个值返回给调用者。这样可以方便SQL存储过程的调试。注意:当你在SQL存储过程中存取SQLCODE和SQLSTATE时,DB2会自动将SQLCODE和SQLSTATE置为零。

可以通过下列语句定义DB2条件处理器:
DECLARE handler-type HANDLER FOR condition
SQL-procedure-statement

其中handler-type可以是如下几种:

CONTINUE:SQL存储过程在执行完条件处理器中的SQL语句后,继续执行出错SQL语句后边的SQL语句。

EXIT: SQL存储过程在执行完条件处理器中的SQL语句后,退出存储过程的执行。

UNDO:这种条件处理器仅限于原子动作(ATOMIC)复合SQL语句,SQL存储过程将会回滚包含该条件处理器的复合SQL语句,并在执行完该条件处理器中的SQL语句后,继续执行原子动作(ATOMIC)复合SQL语句后面的SQL语句。

条件包括如下三种常见情况:

SQLEXCEPTION:在SQL执行过程中返回任何负值。

SQLWARNING:在SQL执行过程中出现警告(SQLWARN0为'W'),或者是任何不是+100的正的SQL返回值,相应的SQLSTATE以'01'开始。

NOT FOUND:SQL返回值为+100或者SQLSTATE以'02'开始。
当然你也可以使用DECLARE语句为特定的SQLSATE定义你自己的条件。

 

 

【编辑推荐】

DB2日期格式更改的实现

DB2日期时间的基础知识

DB2删除数据时的小技巧

DB2事件监控的命令

教您如何实现DB2在线导入

责任编辑:段燃 来源: 互联网
相关推荐

2011-04-11 10:11:25

DB2SQL错误

2010-08-17 15:31:54

DB2 存储过程

2010-11-03 10:12:49

DB2异常处理器

2010-09-01 09:32:08

DB2恢复

2010-11-03 14:28:15

DB2行转列

2010-11-04 13:50:20

DB2在线导入

2010-11-03 11:02:34

DB2存储过程

2010-09-03 14:14:16

SQL删除

2010-11-03 11:30:56

DB2表空间扩容

2010-08-27 14:54:21

DB2批处理脚本

2010-08-31 15:39:25

DB2存储过程

2010-09-30 11:04:47

DB2数据库卸载

2010-08-25 09:56:02

DB2存储过程

2010-10-12 11:07:34

MySQL存储过程

2010-08-18 13:59:04

DB2纯SQL存储过程

2010-09-06 10:54:52

DB2 sql 存储过

2010-09-06 10:43:15

DB2 SQL存储过程

2010-08-26 14:01:59

DB2插入特殊字符

2010-08-25 14:42:46

DB2AIX卸载

2009-01-16 15:00:42

DBASQL存储过程
点赞
收藏

51CTO技术栈公众号