DB2中可以读写的游标怎么定义

最近在做一个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 


转载于:https://www.cnblogs.com/6602300/archive/2006/08/21/482817.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值