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

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

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

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

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

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

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

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

EXEC SQL DECLARE<游标名>CURSOR FOR<SELECT 语句>

定义游标仅仅是一条说明性语句,这时关系数据库管理系统并不执行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分钟,比较容易理解,具体操作用时不长

原创文章 18 获赞 29 访问量 1万+

猜你喜欢

转载自blog.csdn.net/MooM_X/article/details/105699056