数据库语言的练习9 - CURSOR(2020.4.22作业)

Rebecca ·
更新时间:2024-11-15
· 872 次阅读

SQL是面向集合的,一条SQL语句可以产生或处理多条记录:而主语言是面向记录的,一组主变量一次只能存放一条记录。所以仅使用主变量并不能完全满足SQL语句向应用程序输出数据的要求,为此嵌入式SQL引入了游标的概念,用游标来协调这两种不同的处理方式。

游标是系统为用户开设的一个数据缓冲区,存放SQL语句的执行结果,每个游标区都有一个名字。用户可以通过游标逐一获取记录并赋给主变量,交由主语言进一步处理。

必须使用游标的SQL语句有查询结果为多条记录的SELECT语句、CURRENT形式的UPDATE和DELETE语句。

1、查询结果为多条记录的SELECT语句

一般情况下,SELECT语句查询结果是多条记录,因此需要用游标机制将多条记录一次一条地送主程序处理,从而把对集合的操作转换为对单个记录的处理。

T-SQL使用游标的步骤为:

(1)说明游标
用DECLARE 语句为一条SELECT语句定义游标:

EXEC SQL DECLARECURSOR FOR;

定义游标仅仅是一条说明性语句,这时关系数据库管理系统并不执行SELECT语句。

(2)打开游标
用OPEN 语句将定义的游标打开。

EXEC SQL OPEN ;

打开游标实际上是执行相应的SELECT语句,把查询结果取到缓冲区中。这时游标处于活动状态,指针指向查询结果集中的第一条记录。

(3)推进游标指针并取当前记录

EXEC SQLFETCH INTO[][[]]··

其中主变量必须与SELECT语句中的目标列表达式具有一一对应关系。
用FETCH语句把游标指针向前推进一条记录,同时将缓冲区中的当前记录取出来送至主变量供主语言进一步处理。通过循环执行FETCH语句逐条取出结果集中的行进行处理。

(4)关闭游标
用CLOSE语句关闭游标,释放结果集占用的缓冲区及其他资源。

EXEC SQL CLOSE;

游标被关闭后就不再和原来的查询结果集相联系。但被关闭的游标可以再次被打开,与新的查询结果相联系。

2、CURRENT形式的UPDATE和DELETE语句
UPDATE语句和DELETE语句都是集合操作,如果只想修改或删除其中某个记录,则需要用带游标的SELECT语句查出所有满足条件的记录,从中进一步找出要修改或删除的记录,然后用CURRENT形式的UPDATE和DELETE语句修改或删除之。即UPDATE语句和DELETE语句中要用子句:

WHERE CURRENT OF

来表示修改或删除的是最近一次取出的记录,即游标指针指向的记录。

SQL serever使用游标的步骤:
(1)创建游标

DECLARE 游标名 CURSOR FOR 查询语句

(2)打开游标

OPEN 游标名

(3)取数据

FETCH NEXT FROM 游标名 INTO 变量

(4)操作数据
(5)取下一条数据

FETCH NEXT FROM 游标名 INTO 变量

(6)关闭游标

CLOSE 游标名

例:

IF(exists (select * from sys.objects where name = 'proc_cursor')) DROP PROCEDURE proc_cursor GO CREATE PROCEDURE proc_cursor --存储过程 AS DECLARE @Sno char(9)--定义变量 DECLARE @Sname char(20)--定义变量 DECLARE mycursor CURSOR FOR select Sno,Sname from Student --声明游标 OPEN mycursor --打开游标 FETCH NEXT FROM mycursor INTO @Sno,@Sname WHILE(@@FETCH_STATUS=0) --遍历所有的数据 BEGIN PRINT '游标成功取出一条数据:' PRINT @Sno PRINT @Sname PRINT '********************' FETCH NEXT FROM mycursor INTO @Sno,@Sname --取下一条游标数据 END CLOSE mycursor --关闭游标 DEALLOCATE mycursor --删除游标 GO EXEC proc_cursor GO

这是学生表中的内容
在这里插入图片描述
这是代码运行结果
在这里插入图片描述
如果想要分类更加详细的学生信息,只需要在声明游标后写清where语句

总结:40分钟,比较容易理解,具体操作用时不长


作者:与阿轩势力狼狈为奸



数据 数据库语言 cursor 数据库

需要 登录 后方可回复, 如果你还没有账号请 注册新账号