详解SQL游标的用法

这篇文章主要介绍了SQL游标的用法,文中讲解非常详细,配合代码帮助大家更好的理解学习,感兴趣的朋友可以了解下

类型:

1.普通游标 只有NEXT操作

2.滚动游标 有多种操作

1.普通游标

DECLARE @username varchar(20),@UserId varchar(100)
DECLARE cursor_name CURSOR FOR –定义游标
  SELECT TOP 10 UserId,UserName FROM UserInfo
  ORDER BY UserId DESC
OPEN cursor_name –打开游标
FETCH NEXT FROM cursor_name INTO @UserId,@username –抓取下一行游标数据
WHILE @@FETCH_STATUS = 0
  BEGIN
    PRINT ‘用户ID:’+@UserId+’      ‘+’用户名:’+@username

    FETCH NEXT FROM cursor_name INTO @UserId,@username
  END
CLOSE cursor_name –关闭游标
DEALLOCATE cursor_name –释放游标

结果:

用户ID:zhizhi 用户名:邓鸿芝

用户ID:yuyu 用户名:魏雨

用户ID:yujie 用户名:李玉杰

用户ID:yuanyuan 用户名:王梦缘

用户ID:YOUYOU 用户名:lisi

用户ID:yiyiren 用户名:任毅

用户ID:yanbo 用户名:王艳波

用户ID:xuxu 用户名:陈佳绪

用户ID:xiangxiang 用户名:李庆祥

用户ID:wenwen 用户名:魏文文

2.滚动游标

–带SCROLL选项的游标
SET NOCOUNT ON
DECLARE C SCROLL CURSOR FOR –SCORLL 后,有了更多的游标操作(滚动游标)
  SELECT TOP 10 UserId,UserName FROM UserInfo
  ORDER BY UserId DESC
OPEN C
FETCH LAST FROM C  –最后一行的数据,并将当前行为指定行
FETCH ABSOLUTE 4 FROM C –从第一行开始的第4行数据,并将当前行为指定行 这里的n可正可负,n>0 往下翻,n<0 往上翻
FETCH RELATIVE 3 FROM C –相对于当前行的后3行数据,并将当前行为指定行 这里的n可正可负
FETCH RELATIVE -2 FROM C –相对于当前行的前2行数据,并将当前行为指定行
FETCH PRIOR FROM C  —-相对于当前行的前1行数据
FETCH FIRST FROM C  –刚开始第一行的数据,并将当前行为指定行
FETCH NEXT FROM C  –相对于当前行的后1行数据

CLOSE C
DEALLOCATE C

结果(可以参考第一个结果分析):

详解SQL游标的用法

具体FETCH用法:

FETCH 
     [ [ NEXT | PRIOR | FIRST | LAST 
          | ABSOLUTE { n | @nvar } 
          | RELATIVE { n | @nvar } 
        ] 
        FROM 
     ] 
{ { [ GLOBAL ] cursor_name } | @cursor_variable_name } 
[ INTO @variable_name [ ,…n ] ]

Arguments

NEXT

Returns the result row immediately following the current row and increments the current row to the row returned. If FETCH NEXT is the first fetch against a cursor, it returns the first row in the result set. NEXT is the default cursor fetch option.

PRIOR

Returns the result row immediately preceding the current row, and decrements the current row to the row returned. If FETCH PRIOR is the first fetch against a cursor, no row is returned and the cursor is left positioned before the first row.

FIRST

Returns the first row in the cursor and makes it the current row.

LAST

Returns the last row in the cursor and makes it the current row.

ABSOLUTE { n| @nvar}

If n or @nvar is positive, returns the row n rows from the front of the cursor and makes the returned row the new current row. If n or @nvar is negative, returns the row n rows before the end of the cursor and makes the returned row the new current row. If n or @nvar is 0, no rows are returned. n must be an integer constant and @nvar must be smallint, tinyint, or int.

RELATIVE { n| @nvar}

If n or @nvar is positive, returns the row n rows beyond the current row and makes the returned row the new current row. If n or @nvar is negative, returns the row n rows prior to the current row and makes the returned row the new current row. If n or @nvar is 0, returns the current row. If FETCH RELATIVE is specified with n or @nvar set to negative numbers or 0 on the first fetch done against a cursor, no rows are returned. n must be an integer constant and @nvar must be smallint, tinyint, or int.

GLOBAL

Specifies that cursor_name refers to a global cursor.

cursor_name

Is the name of the open cursor from which the fetch should be made. If both a global and a local cursor exist with cursor_name as their name, cursor_name to the global cursor if GLOBAL is specified and to the local cursor if GLOBAL is not specified.

@cursor_variable_name

Is the name of a cursor variable referencing the open cursor from which the fetch should be made.

INTO @variable_name[ ,…n]

Allows data from the columns of a fetch to be placed into local variables. Each variable in the list, from left to right, is associated with the corresponding column in the cursor result set. The data type of each variable must either match or be a supported implicit conversion of the data type of the corresponding result set column. The number of variables must match the number of columns in the cursor select list.

以上就是详解SQL游标的用法的详细内容,更多关于SQL游标用法的资料请关注脚本之家其它相关文章!

来源:脚本之家

链接:https://www.jb51.net/article/188053.htm

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:SEO优化专员,转转请注明出处:https://www.chuangxiangniao.com/p/895514.html

(0)
上一篇 2025年1月4日 00:20:41
下一篇 2025年1月3日 23:50:21

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 电动牙刷需要手动来回刷吗

    电动牙刷是目前很多人群都在使用的生活用品,大部分人都认为电动牙刷清洁口腔会干净很多,但事实的确也是这样。那么,电动牙刷需要手动来回刷吗?电动牙刷来回刷还是不动怎么办?趣丁网为您带来详细解答。 电动牙刷需要手动来回刷吗 不一定。这取决于您使用…

    2025年1月3日
    508.8K00
  • 去死皮膏怎么用效果好

    去死皮膏是比较常见的一种清洁护理产品,它使用起来比较方便,可以有效清洁肌肤表面的死皮,让肌肤变得更加光滑细腻。去死皮膏的使用也有一定技巧,一般先用洗面奶洗脸,然后在用去死皮膏清洁,然后用清水清洁肌肤。 去死皮膏怎么用效果好 步骤: 1、首先…

    2024年12月17日
    616.6K00
  • 洗脸巾是干擦还是湿擦

    一次性洗脸巾在生活中使用频率还是挺高的,那么,洗脸巾是干擦还是湿擦?其实两种方法都可以用,大家根据自己的喜好进行即可,洗脸巾就是充当毛巾的存在,怎么洗脸舒适就怎么使用。 洗脸巾是干擦还是湿擦 洗脸巾是湿擦比较好,因为把洗脸巾打湿之后,使用起…

    2024年12月7日
    158.0K00
  • 用植村秀琥珀洁颜油可以不要洗面奶吗 植村秀琥珀洁颜油用法

    植村秀洁颜油一共有4款,都是植村秀不错的产品,而且一瓶也很大,很经用,适合经常需要带妆的小伙伴。其中一款洁面油是黄棕色的琥珀洁颜油,那么这个洁颜油用了还要洗面奶吗? 用植村秀琥珀洁颜油可以不要洗面奶吗 可以不用洗面奶。 琥珀洁颜油能很好地卸…

    2024年12月7日 科普答疑
    60.7K00
  • 俪纳斯面膜香港有吗 俪纳斯水芙蓉面膜用法

    俪纳斯水芙蓉面膜很小众,但是在欧洲药妆界却很知名,欧洲四大药妆品牌之一。它有着号称“十分钟急救”补水的功效,涂抹式面膜、不用洗,用化妆棉抹掉即可。下面,我们来看看俪纳斯水芙蓉面膜用法,希望能够帮助到大家。 俪纳斯面膜香港有吗  有。 ril…

    2024年12月7日 科普答疑
    806.6K00
  • 修丽可发光瓶用法你都知道吗?集美们看这里

    说到精华只要有一点护肤意识的小姐姐,化妆台上都不会缺少这个物品,而近期一款修丽可发光瓶更是因其功效极佳因而成了许多小姐姐的挚爱。下面小编就分享大家一些修丽可发光瓶的使用方法,希望对大家有所帮助。 修丽可发光瓶的用法你都知道吗 这款精华液我们…

    2024年12月7日
    585.6K00
  • 缓释肥的用法你知道几种?这里帮你总结好了

    养花是当下最受人们欢迎的一件事,而要令花卉植物长得更加的旺盛肥料的选择以及肥料的使用重中之种,缓释肥则因其使肥料中的养分释放速率变慢因而备受大家喜爱,那么缓释肥的用法你知道几种?这里帮你总结好了。 缓释肥的用法你知道几种 众所周知缓释肥就是…

    科普答疑 2024年12月7日
    225.0K00
  • 便携式泡脚桶能洗衣服

    随着天气变冷。人们为了驱寒泡脚便成了大部分人每日必做的事情,但是对于常年出差的人来讲由于木桶和塑料桶太大难于携带,所以泡脚也成了一件很奢侈的是。不过便携泡脚带的出现帮大家很好的解决了这件事,下面小编就和大家一起看看便携式泡脚桶能洗衣服吗。 …

    2024年12月7日
    455.1K00
  • 最好不要和别人共用化妆品

    化妆品并不适合和别人一起用,不然会影响到自己的皮肤,还有可能感染长痘痘,所以,一般接触到皮肤类的,不要和别人一起用,对你自己皮肤不好。那么,怎么婉拒别人借化妆品?一起来看看吧! 最好不要和别人共用化妆品  化妆品中含有水分、矿物质和动植物的…

    2024年12月6日
    194.6K00
  • 医用薄膜手套干净吗

    乳胶手套在生活十分常见,尤其疫情期间它的使用率更是高了一倍,像小编家里现在还有囤货呢,但是更多人在购买医用乳胶手套时都存有干不干净的疑问,下面小编就和大家一起看看。 医用薄膜手套干净吗 说到医用薄膜手套,它的原理就和我们平时使用的那种透明塑…

    2024年12月6日
    14.5K00

发表回复

登录后才能评论

联系我们

156-6553-5169

在线咨询: QQ交谈

邮件:253000106@qq.com

工作时间:周一至周五,9:30-18:30,节假日休息

联系微信