declare my_cursor cursor scroll dynamic



for

select * from t_msg

open my_cursor

declare @name sysname

fetch next from my_cursor into @name

while(@@fetch_status=0)

begin

print 'UserName: ' + @name

--fetch next from my_cursor

fetch next from my_cursor into @name

end

--fetch first from my_cursor into @name

print @name





close my_cursor

deallocate my_cursor

使用游标(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

FOR SELECT * FROM c_example

OPEN E1cursor

FETCH NEXT from E1cursor

WHILE @@FETCH_STATUS = 0

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 语句之前测试该变量的值才能作出正确的判断。

更新数据;

declare my_youbiao cursor

for select * from t_msg

for update

open my_youbiao

fetch next from my_youbiao

while @@fetch_status=0

begin

--update t_msg set msg='1234567890' where current of my_youbiao

update my_youbiao set msg='123' where current of my_youbiao

fetch next from my_youbiao

print 'asdfasd11'

end

close my_youbiao

deallocate my_youbiao

print 'asdfasd'

测试通过:



--select * frommaster..sysprocesses

use test

declare my_cursorcursor scroll dynamic
--scroll表示可以向前或向后移动
dynamic:表示可写也可读,

for

select F3from
temp --定义my_cursor 游标



open my_cursor--打开游标

declare@name
nvarchar(128)--定义一个变量

fetchnext
from my_cursorinto
@name --游标停在第一条记录前面,第一次执行,测试有没有记录存在

while(@@fetch_status=0)--取数据,直到-2即没有记录

begin

print'姓名:
' +
@name

--fetch next from my_cursor

fetchnext
from my_cursorinto
@name

end



--fetch first from my_cursor into @name

print@name

--update temp set F9='zzg' where current of my_cursor



close my_cursor

deallocate my_cursor

SQL游标使用及实例的更多相关文章

  1. 网上看到一份详细sql游标说明 《转载 https://www.cnblogs.com/xiongzaiqiren/p/sql-cursor.html》

     SQL游标(cursor)详细说明及内部循环使用示例 游标 游标(cursor)是系统为用户开设的一个数据缓冲区,存放SQL语句的执行结果.每个游标区都有一个名字,用户可以用SQL语句逐一从游标中获 ...

  2. OCM_第十五天课程:Section6 —》数据库性能调优 _SQL 访问建议 /SQL 性能分析器/配置基线模板/SQL 执行计划管理/实例限制

    注:本文为原著(其内容来自 腾科教育培训课堂).阅读本文注意事项如下: 1:所有文章的转载请标注本文出处. 2:本文非本人不得用于商业用途.违者将承当相应法律责任. 3:该系列文章目录列表: 一:&l ...

  3. 利用navicat创建存储过程、触发器和使用游标的简单实例

    利用navicat创建存储过程.触发器和使用游标的简单实例 标签: navicat存储过程触发器mysql游标 2013-08-03 21:34 15516人阅读 评论(1) 收藏 举报  分类: 数 ...

  4. SQL语句学习手册实例版

    SQL语句学习手册实例版 表操作 例1  对于表的教学管理数据库中的表 STUDENTS ,可以定义如下: CREATE  TABLE  STUDENTS (SNO      NUMERIC (6, ...

  5. 由于启动用户实例的进程时出错,导致无法生成 SQL Server 的用户实例。该连接将关闭。

    错误:由于启动用户实例的进程时出错,导致无法生成SQL Server的用户实例. 原因:添加安装SQLEXPRESS时,估计装在了不同的目录下: 解决方法:关闭Sqlserver及相关的程序,删除目录 ...

  6. SQL迁移到ORACLE实例

    nohup ./command.sh > output 2>&1 & SQL迁移到ORACLE实例 日常运维中,我们经常会有数据库不同类型的迁移,比较多的就是从sql se ...

  7. sql 游标例子 根据一表的数据去筛选另一表的数据

    sql 游标例子 根据一表的数据去筛选另一表的数据 DECLARE @MID nvarchar(20)DECLARE @UTime datetime DECLARE @TBL_Temp table( ...

  8. sql 游标循环当中重新赋值

    sql 游标循环当中的变量必须重新赋值不然变量的值就是前次循环的值

  9. 由于检索用户的本地应用程序数据路径时出错,导致无法生成 SQL Server 的用户实例

    /”应用程序中的服务器错误. 由于检索用户的本地应用程序数据路径时出错,导致无法生成 SQL Server 的用户实例.请确保该用户在此计算机上有本地用户配置文件.该连接将关闭. 堆栈跟踪: [Sql ...

随机推荐

  1. vsftp实现只能上传不能下载、删除权限配置

    vsftpd可以对每个用户特别限制.只要给那个用户建立一个设置文件,然后在文件里设置 在vsftpd.conf里加user_config_dir=/etc/vsftpd/vsftpd_user_con ...

  2. ConcurrentHashMap、CopyOnWriteArrayList、LinkedHashMap

    HashMap中未进行同步考虑,而Hashtable在每个方法上加上了synchronized,锁住了整个Hash表,一个时刻只能有一个线程操作,其他的线程则只能等待,在并发的环境下,这样的操作导致H ...

  3. MySQL计划任务(事件调度器)(Event Scheduler)[转]

    原文链接: http://www.cnblogs.com/c840136/articles/2388512.html MySQL5.1.x版本中引入了一项新特性EVENT,顾名思义就是事件.定时任务机 ...

  4. 洛谷 [P1265] 公路修建

    本题的描述:城市联盟,最短距离.. 使人想到了prim求MST,再一看数据范围:完全图!,那么一定得用prim,因为只有5000个点,所以不加优化的prim就能过. #include <iost ...

  5. bzoj 4869: [Shoi2017]相逢是问候 [扩展欧拉定理 线段树]

    4869: [Shoi2017]相逢是问候 题意:一个序列,支持区间\(a_i \leftarrow c^{a_i}\),区间求和.在模p意义下. 类似于开根操作,每次取phi在log次后就不变了. ...

  6. 51NOD 1705 七星剑 [DP 期望的线性性质]

    传送门 题意: 七颗星,第$i$课星用第$j$个宝石有$p[i][j]$的概率成功,失败将为$g[i][j]$颗星: 第$j$个宝石化费$c[j]$ 求最小期望化费 $MD$本来自己思路挺对的看了半天 ...

  7. C#常用代码片段备忘

    以下是从visual studio中整理出来的常用代码片段,以作备忘 快捷键: eh 用途: 类中事件实现函数模板 private void MyMethod(object sender, Event ...

  8. 树莓派3B上部署运行.net core 2程序

    针对Linxu arm处理器如何部署.net core 2的资料很少,网上找到几篇但都写得不够详细,按照他们教程来撞墙了,折磨了几天终于部署成功了,先上一张运行成功的图 1.windows系统中,在项 ...

  9. 基于layui和bootstrap搭建极简后台管理框架

    年前无聊,想自己搭建一个后台管理框架,对比了easyui.Extjs.H-ui.H+UI.layui几个框架,easyui和Extjs虽然功能强大但是界面实在是接受不了,H+UI和layuiAdmin ...

  10. Kudu存储实战笔记

    有人会问,为啥要用这个叫啥Kudu的,Kudu是啥? 就像官网所说,Kudu是一个针对Apache hadoop 平台而开发的列式存储管理器,在本菜鸟看来,它是一种介于hdfs与hbase的一种存储. ...