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

[经验分享] DB2中可以读写的游标怎么定义

[复制链接]

尚未签到

发表于 2016-11-18 03:41:26 | 显示全部楼层 |阅读模式
  最近在做一个DB2的项目,对DB存储过程中作用游标又有的进一步的了解,先看下面这个文章:
如果对一个表设置了游标,可不可以同时对这个表进行update操作?  
怎么样操作才不会影响游标的位置?  
使用定位操作更改行  
   可更新游标支持通过游标更新行的数据修改语句。当定位在可更新游标中的某行上时,  
   您可以执行更    新或删除操作,这些操作针对用于在游标中建立当前行的基表行。  
   这些就称为定位更新。  

定位更新在打开游标的同一个连接上执行。  
   这就允许数据修改共享与游标相同的事务空间,并且使游标保持的锁不会阻止更新。  

有两种方法在游标中执行定位更新:   
   UPDATE  或  DELETE  语句中的  Transact-SQL  WHERE  CURRENT  OF  子句。  
   数据库  API  定位更新函数或方法,如  ODBC  SQLSetPos  函数。  

使用  Transact-SQL  执行定位更新  
   Transact-SQL  WHERE  CURRENT  OF  子句典型用于  Transact-SQL  存储过程、触发器以及脚本  
(当需要根据游标中特定行进行修改时)。存储过程、触发器、或脚本将:  
   DECLARE  和  OPEN  游标。  
   用  FETCH  语句在游标中定位于一行。  
   用  WHERE  CURRENT  OF  子句执行  UPDATE  或  DELETE  语句。用  DECLARE  语句中的  cursor_name   
   作为  WHERE  CURRENT  OF  子句中的  cursor_name。   
例程:  
declare    cursor_name    cursor    for      
select    *    from    T2  
for  update      
open    cursor_name      
fetch    next    from    cursor_name      
while  @@Fetch_Status  =  0   
begin  
update    T2  set  sname  =  'lx_'  +  sname  --right(sname,len(sname)-3)   
where    current    of    cursor_name      
fetch    next    from    cursor_name      
end  
close  cursor_name  
deallocate  Cursor_Name  

在DB2中也有类似的用法,由于DB2中的SQL语法和SQL SERVER有所不同,所以DB下的存储过程如下:
CREATE PROCEDURE KYJT.SP_TESTT ( )
  SPECIFIC KYJT.SQL060421171925193
  LANGUAGE SQL
  NOT DETERMINISTIC
  CALLED ON NULL INPUT
  MODIFIES SQL DATA
  INHERIT SPECIAL REGISTERS
BEGIN
DECLARE   PNAME VARCHAR(50);
DECLARE PID INT;
DECLARE   v_count int;
DECLARE   SQLSTATE   CHAR(5);     
DECLARE   at_end   INT   DEFAULT   0;   
DECLARE not_found CONDITION FOR SQLSTATE '02000';
  DECLARE C1 CURSOR FOR SELECT ID,NAME FROM KYJT.TESTT FOR UPDATE ;
DECLARE   CONTINUE   HANDLER   FOR   not_found   
SET   at_end   =   1;     
OPEN C1;
INS_LOOP:      
LOOP
FETCH C1 INTO PID,PNAME;  
if at_end = 1 then
LEAVE INS_LOOP;
END IF;
UPDATE KYJT.TESTT A
SET NAME = (SELECT NAME FROM KYJT.TEST B WHERE B.ID=PID) WHERE CURRENT OF C1;
END LOOP;
CLOSE C1;
END

运维网声明 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-301721-1-1.html 上篇帖子: 批处理数据--db2备份数据 下篇帖子: Linux下卸载DB2,WebSphere
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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