DB2中可以读写的游标的定义
创始人
2024-07-26 02:01:42
0

导读:DB2中游标是非常重要的一个概念,游标提供了一种对从表中检索出的数据进行操作的灵活手段,就本质而言,游标实际上是一种能从包括多条数据记录的结果集中每次提取一条记录的机制。

使用定位操作更改行
可更新游标支持通过游标更新行的数据修改语句。当定位在可更新游标中的某行上时,您可以执行更 新或删除操作,这些操作针对用于在游标中建立当前行的基表行。 这些就称为定位更新。 定位更新在打开游标的同一个连接上执行。 这就允许数据修改共享与游标相同的事务空间,并且使游标保持的锁不会阻止更新。

有两种方法在游标中执行定位更新:
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.  在DB2数据库中很难理解的单词catalog
  2. 深入讲解游标类型为什么会产生数据检索
  3. 游标脚本性能问题详解之游标分类特点篇
  4. 游标为何物,请你看这里

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
各种千兆交换机的数据接口类型详... 千兆交换机有很多值得学习的地方,这里我们主要介绍各种千兆交换机的数据接口类型,作为局域网的主要连接设...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
规避非法攻击 用好路由器远程管... 单位在市区不同位置设立了科技服务点,每一个服务点的员工都通过宽带路由器进行共享上网,和单位网络保持联...
范例解读VB.NET获取环境变... VB.NET编程语言的使用范围非常广泛,可以帮助开发人员处理各种程序中的需求,而且还能对移动设备进行...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...