在SqlServer存储过程中使用Cursor(游标)操作记录
1. 为何使用游标: 使用游标(cursor)的一个主要的原因就是把集合操作转换成单个记录处理方式。用SQL语言从数据库中检索数据后,结果放在内存的一块区域中,且结果往往是一个含有多个记录的集合。游标机制允许用户在SQL server内逐行地访问这些记录,按照用户自己的意愿来显示和处理这些记录。
2. 如何使用游标: 一般地,使用游标都遵循下列的常规步骤:
(1) 声明游标。把游标与T-SQL语句的结果集联系起来。
(2) 打开游标。
(3) 使用游标操作数据。
(4) 关闭游标。
2.1. 声明游标 DECLARE CURSOR语句SQL-92标准语法格式: DECLARE 游标名 [ INSENSITIVE ] [ SCROLL ] CURSOR FOR sql-statement Eg: Declare MycrsrVar Cursor FOR Select * FROM tbMyData
2.2 打开游标 OPEN MycrsrVar
当游标被打开时,行指针将指向该游标集第1行之前,如果要读取游标集中的第1行数据,必须移动行指针使其指向第1行。就本例而言,可以使用下列操作读取第1行数据:
FETCH FIRST from E1cursor 或 FETCH NEXT from E1cursor
2.3 使用游标操作数据 下面的示例用@@FETCH_STATUS控制在一个WHILE循环中的游标活动
/* 使用游标读取数据的操作如下。*/
DECLARE E1cursor cursor /* 声明游标,默认为FORWARD_ONLY游标 */
FOR SELECT * FROM c_example OPEN E1cursor /* 打开游标 */
FETCH NEXT from E1cursor /* 读取第1行数据*/
WHILE @@FETCH_STATUS = 0 /* 用WHILE循环控制游标活动 */ BEGIN
FETCH NEXT from E1cursor /* 在循环体内将读取其余行数据 */
END CLOSE E1cursor /* 关闭游标 */
DEALLOCATE E1cursor /* 删除游标 */
2.4 关闭游标
使用CLOSE语句关闭游标 CLOSE { { [ GLOBAL ] 游标名 } | 游标变量名 }
使用DEALLOCATE语句删除游标,其语法格式如下: DEALLOCATE { { [ GLOBAL ] 游标名 } | @游标变量名
3. FETCH操作的简明语法如下:
FETCH
[ NEXT | PRIOR | FIRST | LAST] FROM { 游标名 | @游标变量名 } [ INTO @变量名 [,…] ] 参数说明:
NEXT 取下一行的数据,并把下一行作为当前行(递增)。由于打开游标后,行指针是指向该游标第1行之前,所以第一次执行FETCH NEXT操作将取得游标集中的第1行数据。NEXT为默认的游标提取选项。 INTO @变量名[,…] 把提取操作的列数据放到局部变量中。列表中的各个变量从左到右与游标结果集中的相应列相关联。各变量的数据类型必须与相应的结果列的数据类型匹配或是结果列数据类型所支持的隐性转换。变量的数目必须与游标选择列表中的列的数目一致。
--------------------------------------------------------------------------------------------------------------------------------
每执行一个FETCH操作之后,通常都要查看一下全局变量@@FETCH_STATUS中的状态值,以此判断FETCH操作是否成功。该变量有三种状态值:
· 0 表示成功执行FETCH语句。 · -1 表示FETCH语句失败,例如移动行指针使其超出了结果集。 · -2 表示被提取的行不存在。
由于@@FETCH_STATU是全局变量,在一个连接上的所有游标都可能影响该变量的值。因此,在执行一条FETCH语句后,必须在对另一游标执行另一FETCH 语句之前测试该变量的值才能作出正确的判断。
转载于:https://www.cnblogs.com/zhangdp/archive/2012/12/22/2829544.html
在SqlServer存储过程中使用Cursor(游标)操作记录相关推荐
- SqlServer存储过程中循环的使用
1.while循环 格式示例如下: declare @i int set @i=1 while @i<30 begin insert into test (userid) values(@i) ...
- SQLServer存储过程中break、continue及return的使用
SQLServer编写存储过程中,我们会使用break.continue及return来中断程序的执行,这三者有什么区别,在此做以说明 break 退出 WHILE循环,执行循环体以后的语句,示例代码 ...
- mysql 多个游标_mysql 存储过程中使用多游标
mysql的存储过程可以很方便使用游标来实现一些功能,存储过程的写法大致如下: 先创建一张表,插入一些测试数据:DROP TABLE IF EXISTS netingcn_proc_test; CRE ...
- mysql 存储过程 out cursor_Mysql存储过程中使用cursor
一.表 学生表 CREATE TABLE `t_student` ( `stuNum` int(11) NOT NULL auto_increment, `stuName` varchar(20) d ...
- 递归存储过程中使用cursor
注意定义成local类型的cursor ! PROCEDURE sp_get_all_lineal_parent @node_id int, @lineal_path varchar(200) out ...
- wdcp查看mysql日志_查看修改服务器中的WDCP数据库操作记录
今天一老客户要使用本地工具(Navicat)操作主机中的MySQL,主机已开放3306端口,IDC后台安全策略也增加了3306,但是还是拒绝连接,出现上面的提示信息.百度了一下,说是主机名要使用&qu ...
- CentOS中一些基本的操作记录
1)切换到root su root 输入你的密码.我的是123 转载于:https://www.cnblogs.com/songjl/p/7571291.html
- Oracle存储过程中使用游标来批量解析CLOB字段里面的xml字符串:
摘要:之前在项目中使用到了Oracle数据库中通过触发器去调用存储过程执行数据解析并Update到对应的数据表中,但是,经过一段时间的测试使用发现,如果job那天停掉了,然后你再重新新建job的话,这 ...
- java中sql去除游标_java.sql.SQLException:-ORA-01000:已超过最大打开游标
小编典典 ORA-01000(最大打开游标错误)是Oracle数据库开发中极为常见的错误.在Java上下文中,当应用程序尝试打开比数据库实例上配置的游标更多的ResultSet时,就会发生这种情况. ...
最新文章
- 【UE5教程】影棚拍摄于虚拟场景合成制作流程学习
- 爱奇艺称告别唯流量时代 正式关闭显示前台播放量
- java form的时间格式_SpringMvc接收日期表单提交,自动转换成Date类型方法
- 材料凝固计算机模拟,金属基复合材料凝固过程计算机模拟Ⅲ.pdf
- Freemarker中通过request获得contextPath
- 算法题存档20190127
- hadoop生态搭建(3节点)-07.hive配置
- Python的time,datetime,string相互转换
- Scratch-Q版三国小人物角色素材分享,值得您的收藏!
- AVR单片机教程——DAC
- Windows 11 Manager(win11优化大师)官方中文版V1.0.0 | windows11优化软件下载
- ERROR: The process abc.exe with PID 6588 could not be terminated.
- Boundary loss for highly unbalanced segmentation
- ubuntu 16.04.7通过get-pip.py安装pip 20.3.4
- New情报:APT28,TA505 黑产组织,VenusLocker Ransomware组织,ROKRAT远控
- 【踩坑日记 · 嵌入式 Linux】在香橙派 Zero 2 上编译安装 CH340 驱动(OrangePi Zero 2)
- Knockoutjs官网翻译系列(二) Observable 数组
- DL之RNN:人工智能为你写周董歌词——基于TF利用RNN算法实现【机器为你作词】、训练测试过程全记录
- Android-四大天王
- H264 demux后AVPacket送去decode时出错