实验_游标.doc
文本预览下载声明
实验5 游标
实验目的:掌握游标的声明、打开、推进、关闭与释放,熟练使用游标
实验环境准备:创建数据库ch8db,并在其中创建表stuinfo,代码如下:
create database ch8db
go
use ch8db
create table stuinfo
(
sno char(7) primary key,
sname char(10),
ssex char(2),
birth smalldatetime,
grade smallint
)
insert into stuinfo values(2009001,Tom,男,1990-1-5,90)
insert into stuinfo values(2009002,Jerry,女,1990-2-11,90)
insert into stuinfo values(2009003,Betty,男,1990-3-24,90)
insert into stuinfo values(2009004,John,男,1990-4-25,90)
insert into stuinfo values(2009005,Peter,女,1990-5-18,80)
insert into stuinfo values(2009006,Mosuli,女,1990-6-17,80)
insert into stuinfo values(2009007,Sula,男,1990-7-7,80)
insert into stuinfo values(2009008,Herry,女,1990-8-06,80)
insert into stuinfo values(2009009,Charli,男,1990-9-22,80)
实验知识准备:游标的使用步骤
1、声明游标:确定游标的属性及指示的查询结果集
2、打开游标:分析定义游标的SELECT语句,形成结果集
3、推进游标,以行为单位从结果集中获取数据
4、关闭游标:停止处理查询
5、释放游标:释放分配给游标的所有存储资源
实验内容:
一、声明游标
DECLARE 游标名 [SCROLL] CURSOR
FOR select 语句描述
[FOR {READ ONLY|UPDATE [OF 列名表]}]
说明:
1、SCROLL选项省略时,称为只进游标,即游标只能向前滚动,提取数据的选项只能用NEXT;加上此选项时称为滚动游标,即游标可随意滚动,提取数据的选项可用(FIRST、LAST、PRIOR、NEXT、RELATIVE、ABSOLUTE)
2、READ ONLY表示游标是只读的
3、UPDATE 表明游标是可更新的,可在后面加OF短语指明游标内可更新的列,若未指定列表则可更新所有列
操作:分别声明如下四种类型的游标
二、打开游标
OPEN 游标名
如:打开游标 cur_ro_fd的命令为
三、读取游标
FETCH [NEXT|PRIOR|FIRST|LAST |ABSOLUTE {n|@nvar} |RELATIVE {n|@nvar}]
FROM 游标名
[INTO @变量名1[, . . . @变量名n ] ]
说明: n是整型常量,@nvar是smallint、tinyint或int型变量
ABSOLUTE n:
当n0时表示返回从游标头开始的第n行数据,并将返回行当成新的当前行;
当n0时表示返回从游标尾之前的第n行数据,并将返回行当成新的当前行;
当n=0时表示没有行返回
RELATIVE n:
当n0时表示返回当前行之后的第n行数据,并将返回行当成新的当前行;
当n0时表示返回当前行之前的第n行数据,并将返回行当成新的当前行;
当n=0时表示返回当前行
如:读取游标 cur_ro_fd的命令为
注:执行时,这三条命令必须选中一起来执行,否则出错。
选中这三行后,多次点击执行按钮,观察结果的变化
四、关闭游标
CLOSE 游标名
如:关闭游标 cur_ro_fd的命令为
五、释放游标
DEALLOCATE 游标名
如:释放游标 cur_ro_fd的命令为
注:这个命令就不要执行了,因后面还要用到这个游标,否则后面用时要再重新创建一次该游标
六、游标测试
1、测试游标只前进情况与可前进可后退的滚动情况
注:以下红方框里的代码必须选中同时执行,不能单独一条一条地执行
2、测试游标的只读与可更新情况
显示全部