标签:column 记录 sql https 连接 过程 com 智能 变量
部分参考自:https://www.cnblogs.com/knowledgesea/p/3699851.html
游标是取用一组数据并能够一次与一个单独的记录进行交互的方法,可以定位到结果集中的某一行,多数据进行读写,也可以移动游标定位到你所需要的行中进行操作数据。有时,确实不能通过在整个行集中修改或者甚至选取数据来获得所需要的结果,故需要逐一进行处理。
主要用处(存储过程):
1. 声明游标
语法:
DECLARE cursor_name CURSOR [ LOCAL | GLOBAL ] [ FORWARD_ONLY | SCROLL ] [ STATIC | KEYSET | DYNAMIC | FAST_FORWARD ] [ READ_ONLY | SCROLL_LOCKS | OPTIMISTIC ] [ TYPE_WARNING ] FOR select_statement [ FOR UPDATE [ OF column_name [ ,...n ] ] ]
参数说明:
2. 打开游标
语法:
OPEN [ Global ] cursor_name | cursor_variable_name
3. 使用和导航游标
语法:
FETCH [ [Next|prior|Frist|Last|Absoute n|Relative n ] from ] [Global] cursor_name [into @variable_name[,....]]
参数说明:
例如:FETCH NEXT FROM 游标名称 INTO 变量名1
意为发出第一个FETCH,即表明要检索特定记录的命令,并将该值放置在哪一个变量中。
每当提取一行时,就会更新@@FETCH_STATUS,通过检测全局变量@@Fetch_Status的值,获得提取状态信息。
其可能的值是:
0 Fetch语句成功——一切正常;
-1 Fetch语句失败——找不到记录(还没有到达游标的末尾,但自打开游标以后,记录已经被删除);
-2 Fetch语句失败——这一次是由于已经超出了游标中的最后一条(或者第一条)记录。
4. 关闭游标
游标打开后,服务器会专门为游标分配一定的内存空间存放游标操作的数据结果集,同时使用游标也会对某些数据进行封锁。所以游标一旦用过,应及时关闭,避免服务器资源浪费。
CLOSE [ Global ] cursor_name | cursor_variable_name
5. 释放游标
删除游标,释放资源
DEALLOCATE [ Global ] cursor_name | cursor_variable_name
DECLARE sc_cursor CURSOR FOR SELECT Grade FROM SC WHERE Cno=@course_cno OPEN sc_cursor FETCH NEXT FROM sc_cursor INTO @stu_grade IF(@@FETCH_STATUS<>0) PRINT ‘没有考该课程的学生‘ WHILE @@FETCH_STATUS=0 BEGIN IF(@stu_grade<60) SET @stu_ccount+=1 IF(@stu_grade>=60 AND @stu_grade<90) SET @stu_bcount+=1 IF(@stu_grade>=90 AND @stu_grade<=100) SET @stu_acount+=1 FETCH NEXT FROM sc_cursor INTO @stu_grade END CLOSE sc_cursor DEALLOCATE sc_cursor
标签:column 记录 sql https 连接 过程 com 智能 变量
原文地址:https://www.cnblogs.com/chenloveslife/p/9135749.html