MS SQL cursor 游标使用

本文详细介绍了SQL Server中的游标概念、类型、操作过程,包括声明、打开、提取数据和关闭游标。游标提供了一种处理结果集中单条记录的方法,分为向前只读游标、静态游标、动态游标和键集驱动游标。文中还给出了游标的多种类型及其适用场景,并通过实例展示了如何在SQL Server中使用游标打印报表。
摘要由CSDN通过智能技术生成

一、游标包括两个部分:
1、游标结果集      由定义该游标的select语句返回的行的集合
2、游标位置         指向这个集合中某行的指针

二、游标处理过程:
使用declare 语句声明
使用open语句打开
使用fecth语句从游标中提取数据
判断是否为空,为空no则返回上一步,不为空yes
使用close关闭
使用deallocate释放

1、声明游标:
declare 游标名 [insensitive] [scroll] cursor for select语句     [for {read only | update [of 列[,....n]]}]
说明: insensitive 定义一个游标,以创建将由该游标使用的数据的临时复本。
            scroll指定所有的提取项(first,last,prior,next,relative,absolute)均可用,默认为next
            在select语句中不允许用compute,compute by ,for browse和into

2、打开游标:
open { {[globa] 游标名} | 游标变量
说明:global 为全局游标

3、从打开的游标中提取行

三、游标类型
Const adOpenForwardOnly = 0
前向游标,为缺省游标,提供最快的运行性能。用它打开recordset,从对至尾顺序取得所有结果。它不支持向后滚动,只允许在结果间单向移动。

Const adOpenKeyset = 1
静态游标,反映第一次打开游标时表中数据的状态,游标无法查明底层表中的数据行是否更新过、删除过或添加了新的数据。不过与只能前移的洲标不同,静态游标可以在结果间前后滚动。

Const adOpenDynamic = 2
键盘驱动的游标,可以查询表中底层数据行的某些变化,但不是全部。它特别是可以准确反映数据是否更新过。但它不能查明其它用户是否曾删除过数据行(删除掉的数据行在recordset中会留下空洞)。键盘驱动的游标支持在结果间前后滚动。

Const adOpenStatic = 3
动态游标,是最丰富的游标类型。游标打开时可以查询其他用户对表的任何改动,而且支持滚动。

加锁类型
Const adLockReadOnly = 1
缺省的上锁类型,只读方式上锁允许多个用户同时读取同样的数据,但不能改变数据。

Const adLockPessimistic = 2
以悲观上锁方式打开数据对象。该方式假定在你编辑记录时会有其它用户访问数据。此时一旦你开始编辑记录,其它用户就不能访问该数据。

Const adLockOptimistic = 3
以乐观上锁方式打开数据对象。该方式假定在你编辑记录时不会有其它用户访问数据。在完成改变之前,其它用户不能访问该记录。

Const adLockBatchOptimistic = 4
执行多行批处理更新时使用这种类型

六、综合实例
用sql server游标语句打印报表
DECLARE authors_cursor CURSOR FOR
SELECT au_id, au_fname, au_lname
FROM authors
WHERE state = "UT"
ORDER BY au_id

OPEN authors_cursor

FETCH NEXT FROM authors_cursor
INTO @au_id, @au_fname, @au_lname

WHILE @@FETCH_STATUS = 0
BEGIN
PRINT " "
SELECT @message = "----- Books by Author: " +
@au_fname + " " + @au_lname

PRINT @message

-- Declare an inner cursor based
-- on au_id from t

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值