`
liulanghan110
  • 浏览: 1076634 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

DB2游标

阅读更多

游标一般用来迭代结果集中的行

为了在一个过程中处理一个游标的结果,需要做以下事情:

在存储过程块的开头部分 DECLARE 游标。

打开该游标。

将游标的结果取出到之前已声明的本地变量中(隐式游标处理除外,在下面的 FOR 语句中将对此加以解释)。

关闭该游标。(注意:如果现在不关闭游标,当过程终止时将隐式地关闭游标)。

注:游标的申明如果放在中间段,要用”begin。。。end;”.段分割标志分割开;

 

游标使用的步骤如下:

1、说明游标。说明游标的时候并不执行select语句。
declare <游标名> cursor for <select语句>;

2、打开游标。打开游标实际上是执行相应的select语句,把查询结果读取到缓冲区中。这时候游标处于活动状态,指针指向查询结果集的第一条纪录。
open <游标名>;

3、推进游标指针并读取当前纪录。用fetch语句把游标指针向前推进一条纪录,同时将缓冲区中的当前纪录读取出来送到变量中。fetch语句通常用在一个循环结构体中,通过循环执行fetch语句逐条取出结果集中的行进行处理。现在好多数据库中,还允许任意方向任意步长易懂游标指针,而不仅仅是把游标指针向前推进一行了。
fetch <游标名> into <变量1>,<变量2>...

4、关闭游标。用close语句关闭游标,释放结果集占用的缓冲区及其他资源。游标关闭后,就不再和原来的查询结果集相联系。但游标可以再次打开,与新的查询结果相联系。
close <游标名>;

 

基本结构:

定义游标:

DECLARE  游标名 CURSOR FOR

Select 语句;

打开游标:

OPEN 游标名;

取值:

FETCH 游标名 INTO 变量列表

 

游标例子:

--先插入测试数据

create table test(id int,city char(20))

insert into  test values(1,'wuhan'),(2,'hangzhou'),(3,'chengdu')

 

create procedure Test(

out v_message varchar(500)

)

LANGUAGE SQL

BEGIN

DECLARE v_city char(20);

DECLARE v_count int;

 

SET v_message = '';

select count(*) into v_count from test;

BEGIN

DECLARE v_CUR CURSOR FOR SELECT city FROM test FOR READ ONLY;

OPEN v_CUR;

WHILE v_count > 0 DO

FETCH v_CUR INTO v_city;

set v_message = v_message ||v_city||' ';

set v_count = v_count -1;

end while;

END;

 

END@

运行结果为:

call Test(?)

completed successfully.

 

输出参数的值

--------------------------

参数名 V_MESSAGE

参数值 wuhan                hangzhou             chengdu             

返回状态 = 0

Statement processed successfully in 4.39 secs.

 

除了这种结构外,还有一种使用for的游标的结构,例子如下:

create procedure Test(

out v_message varchar(500)

)

LANGUAGE SQL

BEGIN

DECLARE v_city char(20);

DECLARE v_count int;

 

SET v_message = '';

 

FOR V1 AS CURSOR1 CURSOR FOR  select city as v_city from test

DO

set v_message = v_message||v_city||' ';

END FOR;  

 

END@

运行结果:

call Test(?)

completed successfully.

 

输出参数的值

--------------------------

参数名 V_MESSAGE

参数值 wuhan                hangzhou             chengdu             

 

返回状态 = 0

Statement processed successfully in 0.18 secs.

可以看到第二种游标使用起来非常简单。但是它不能使用 with hold 选项,这个with hold有什么用呢?默认情况下,,CommitRollback,游标将被关闭。所以如果游标循环体内有CommitRollback时,不能使用for形式的游标。但是第一种游标可以使用,可以在第一种游标定义时加上with hold 选项,那么在游标循环体内CommitRollback时,游标也不会关闭。

使用CommitRollback也不会关闭的游标,如下:

DECLARE v_CUR CURSOR with hold for SELECT city FROM test FOR READ ONLY;

如果要修改游标当前记录,需要定义可修改的游标,如下:

DECLARE v_CUR CURSOR for SELECT city FROM test FOR update;;

注意:for update 不能和 GROUP BY DISTINCT ORDER BY FOR READ ONLYUNION, EXCEPT UNION ALL除外)一起使用。

 

DB2存储 过程中,除了迭代结果集中的行以外,游标还可以做更多的事情。游标还可用于将结果集返回给调用程序或其他过程。

 

WITHOUT RETURN/WITH return   选项指定游标的结果表是否用于作为从一个过程中返回的结果集。

WITH RETURN TO CALLER   选项指定将来自游标的结果集返回给调用者,后者可以是另一个过程或一个客户机应用程序。这是默认选项。

WITH RETURN TO CLIENT   选项指定将来自游标的结果集返回给客户机应用程序,绕过任何中间的嵌套过程。

若要从一个过程中返回结果集,需要:

创建一个过程,创建时指定 DYNAMIC RESULT SETS 子句。

声明游标,声明时指定 WITH RETURN 子句。

打开该游标,并使之保持 open 状态。

如果关闭该游标,则结果集将不能返回给调用者应用程序。

下例 演示了一个游标的声明,该游标从一个过程中返回一个结果集:

create procedure Test(

out v_message varchar(500)

)

DYNAMIC RESULT SETS 1

LANGUAGE SQL

BEGIN

--异常处理

DECLARE SQLCODE INT;

DECLARE v_errCode INT DEFAULT 0;

DECLARE CONTINUE HANDLER FOR SQLEXCEPTION

BEGIN

SET v_errCode = SQLCODE;

END; 

 

--使用游标返回结果集

BEGIN

DECLARE v_cur CURSOR WITH HOLD WITH RETURN TO CALLER FOR

SELECT * FROM test;

OPEN v_cur;

END;

 

RETURN v_errCode;

END@

运行结果:

call Test(?)

completed successfully.

 

输出参数的值

--------------------------

参数名 V_MESSAGE

参数值 -

 

 

结果集 1

--------------

 

ID          CITY               

----------- --------------------

1 wuhan              

2 hangzhou           

3 chengdu            

 

3 条记录已选择。

 

返回状态 = 0

分享到:
评论
1 楼 frustrate 2012-10-30  
写的很好,简单明了

相关推荐

    DB2游标及动态SQL

    ### DB2游标及动态SQL详解 #### 一、DB2游标概念与使用 **1.1 游标简介** 在DB2中,游标是一种用于遍历查询结果集的强大工具。它允许用户一行一行地处理数据,这对于需要逐行处理数据的应用场景非常有用。游标通常...

    DB2 中游标的使用

    游标是DB2数据库中一个强大的功能,它可以帮助我们在复杂的逻辑处理中更好地管理数据。正确理解和使用游标对于提高应用程序的效率至关重要。通过本文的介绍,相信您已经掌握了DB2中游标的基本使用方法及注意事项。在...

    DB2循环递归实例很有用的

    ### DB2循环递归查询详解 #### 一、引言 在数据库操作中,经常会遇到需要处理层次结构数据的情况,例如组织结构、产品分类等。这些数据的特点是具有明显的层级关系,而传统的SQL查询往往难以高效地处理这类问题。...

    不定长的select交叉表查询,而且不用游标 sql 行列转化

    ### 不定长的SELECT交叉表查询,且不用游标:SQL行列转换技术解析 #### 一、背景介绍 在数据库管理中,数据的组织形式多种多样,有时我们需要将原本存储为行的数据转换成列的形式展示,反之亦然。这种转换在实际...

    DB2 HELP DB2ir

    DB2ir还支持一些高级功能,如事务管理(BEGIN、COMMIT、ROLLBACK)、游标(DECLARE、OPEN、FETCH、CLOSE)、子查询和存储过程调用。此外,它具有智能提示和自动完成功能,以提高用户输入效率。 在实际工作中,掌握...

    DB2到GreenPlum/PostgreSQL的转换指南

    ### DB2到GreenPlum/PostgreSQL的转换指南 #### 1. 引言 ##### 1.1 目的 本指南旨在帮助用户理解从DB2迁移到GreenPlum或PostgreSQL过程中所涉及的关键技术和注意事项。由于这两种数据库系统之间存在显著差异,因此...

    DB2数据库存储过程小结

    以下是对DB2存储过程及其在使用游标方面的详细解释。 1. **存储过程的基本概念** - 存储过程是一组预先编译好的SQL语句,存储在数据库服务器上,可以被多次调用,减少了网络通信和解析时间。 - 它们可以接受输入...

    IBM DB2认证题库

    实际上,DB2 CLI提供了一种无需显式声明游标的接口,因此选择D是正确的。 第二部分的问题涉及游标操作。在已知DECLARE csr1 DYNAMIC SCROLL CURSOR FOR SELECT * FROM employee;之后,要从结果集的末尾开始获取数据...

    db2学习代码例子(代码为转载网上)

    1. `DECLARE CURSOR statement .doc`:这部分内容可能详细介绍了DB2中的声明游标(DECLARE CURSOR)语句,它用于定义一个游标,允许程序按需逐行处理查询结果。在DB2中,游标是处理大量数据的有效工具,特别是在需要...

    DB2 Windows Server 64位 ODBC驱动

    7. **游标和批处理**: 支持游标操作,允许应用程序按需获取数据,同时批处理功能可以减少网络通信次数,提高批量操作性能。 8. **错误处理和日志记录**: 提供详细的错误信息和日志功能,便于排查问题和监控数据库...

    ORACLE转DB2对照全解

    **注意:** Oracle和DB2中的游标语法类似,但在DB2中,`DECLARE`关键字用于声明游标。 ##### 3.2 UDF和触发器中显式游标的转换 **Oracle:** ```sql CREATE OR REPLACE FUNCTION get_data RETURN NUMBER IS CURSOR...

    DB2编程基础要点 sql 存储过程

    总之,DB2编程基础要点包括存储过程的创建、临时表的使用、指定数量记录的选取、游标的管理和事务控制,以及模拟`DECODE`函数的操作。掌握这些要点有助于编写高效、可靠的DB2应用程序。在实际工作中,了解并熟练应用...

    db2 存储过程语法与实例

    DB2存储过程是一种在数据库管理系统中预编译的SQL代码集合,它允许开发人员封装复杂的业务逻辑和数据处理操作,并可以被多次调用。DB2作为一款强大的关系型数据库管理系统,其存储过程功能强大,提高了应用程序的...

    超级db2_jar.zip

    此外,DB2还提供了丰富的功能,如事务管理、游标、存储过程、视图、触发器等,这些都可以通过JDBC接口在Java程序中进行操作。在实际开发中,你可能还会遇到性能优化、连接池配置、错误处理等问题,这些都是Java与DB2...

    db2_查询锁方法

    -- 创建游标并执行查询 db2 -c "declare c1 cursor for select * from staff where job = 'Sales' for update" db2 -c "open c1" db2 -c "fetch c1" -- 查询锁信息 db2 select * from SYSIBMADM.LOCKS_HELD ``` 该...

    db2 开发基础课程

    - **游标**:解释游标的原理和使用方法,以及如何提高游标的性能。 - **索引优化**:探讨不同类型的索引(如B-tree索引、位图索引等),并分析它们对查询性能的影响。 - **并发控制**:介绍DB2中的并发控制机制,如...

    db2数据库jar包

    - **游标**:在处理大量数据时,游标允许按需逐行读取结果集,而不是一次性加载所有数据。 总的来说,DB2数据库JAR包是Java开发者与DB2数据库进行交互的基础,理解和正确使用这些驱动文件对于构建高效、可靠的Java...

    PYTHON使用DB2开发.pdf

    在实际应用中,Db2-Python应用程序可能会用到一些特殊对象,例如游标(cursor)用于控制查询的执行和结果的检索,以及连接(connection)对象用于保持与数据库的会话。此外,还可以通过预编译语句(prepared ...

    IBM DB2 JAR包

    6. **游标和批处理**:游标允许在结果集中向前或向后导航,而批处理则允许一次性提交多个SQL命令,提高效率。 7. **数据库元数据**:通过`DatabaseMetaData`接口,可以获取关于数据库的元信息,如表结构、列信息、...

Global site tag (gtag.js) - Google Analytics