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分钟,比较容易理解,具体操作用时不长