C114首页 | 新闻 技术 市场 会展 黄页 人物 | 3G NGN VoIP IPTV WiMax FTTH |          通信人家园 | 通信人博客 | 通信商情网 | 通信人才网 | English
近期导读

·微软,你操之过急了!

·C网发展的最大弊端

·预测电信招标中三星份额

  技术 - 学院 - 网络基础 - 正文
DB2中游标的使用方法以及存储过程的写法
 
( 2008/7/16 14:37 )
本文关键字: 

问题1:

什么时候才会发生not found异常 ,以及db2中sqlcode的值是如何变化的?

在db2中,一条select 语句也有可能发生not found异常,譬如:

declare sqlcode integer default 0;

declare sql_code integer default 0;

declare classCode varchar(40) ;

select app_class_code into classCode from kf_app_class where app_name='无效记录';

set sql_code=sqlcode;

如果此时没有检索到记录,那么sqlcode的值为100,有的话为0;

我们可以定义NOT FOUND 异常处理

declare sqlcode integer default 0;

declare sql_code integer default 0;

declare classCode varchar(40) ;

begin

declare continue handler for not found

begin

--注如果发生not found那么此时的sqlcode必定为100

set sql_code=sqlcode;/*在这里sqlcode的值为100;*/

--如果再次得到sqlcode的值那么它的值变为0

set sql_code=sqlcode;/*这里sqlcode变成了0,因为上一条语句执行成功了,那么sqlcode变成了0*/

end;

select app_class_code into classCode from kf_app_class where app_name='无效记录';

set sql_code=sqlcode;/*同理此时如果没有取到数据,那么会进declare continue handler ,返回后sqlcode的值也为0*/

end;

所以我们可以通过两种方法来捕获和处理not found

作者:韩丹   来源:赛迪网
  你是通信人才吗? C114通信人才网
  是通信人才就要上专业通信人才网! 专业、高效、低成本、资源广!
  助你迅速找到满意工作! 拥有中国最全的通信行业人才数据库资源。
C114-AdKey 行业广告系统 
C114 提醒您:1.尊重网上道德,遵守国家的各项法律法规;2.承担一切因为您的行为而导致的相关法律责任;

3.新闻留言板管理人员有权删减留言中的内容;4.您在留言板发表的作品,C114有权站内转载。

[参与本留言即表明您已经阅读并接受上述条款]

 
Copyright©1999-2008 c114 All Right Reserved
上海荧通网络信息技术有限公司版权所有
南方广告业务部: 021-54451141,54451142 E-mail:c114@c114.net
北方广告业务部: 010-63533177,63533977 E-mail:shi@c114.net.cn
编辑部联系:021-54451141,54451142 E-mail:editor@c114.net.cn
服务热线:021-54451141,54451142