加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

sqlserver 游标使用

发布时间:2020-12-12 12:56:05 所属栏目:MsSql教程 来源:网络整理
导读:Transaction-SQL游标 ??????该游标是基于Declare Cursor 语法,主要用于Transaction-SQL脚本、存储过程以及触发器中。Transaction-SQL游标在服务器处理由客户端发送到服务器的Transaction-SQL语句。 ??????在存储过程或触发器中使用Transaction-SQL游标的过
Transaction-SQL游标

??????该游标是基于Declare Cursor 语法,主要用于Transaction-SQL脚本、存储过程以及触发器中。Transaction-SQL游标在服务器处理由客户端发送到服务器的Transaction-SQL语句。

??????在存储过程或触发器中使用Transaction-SQL游标的过程为:

??????(1)声明Transaction-SQL变量包含游标返回的数据。为每个结果集列声明一个变量。声明足够大的变量来保存列返回的值,并声明变量的类型为可从数据类型隐式转换得到的数据类型。

??????(2)使用Declare Cursor语句将Transaction-SQL游标与Select语句相关联。还可以利用Declare Cursor定义游标的只读、只进等特性。 

??????(3)使用Open语句执行Select语句填充游标。

??????(4)使用Fetch Into语句提取单个行,并将每列中得数据移至指定的变量中。注意:其他Transaction-SQL语句可以引用那些变量来访问提取的数据值。Transaction-SQL游标不支持提取行块。

??????(5)使用Close语句结束游标的使用。注意:关闭游标以后,该游标还是存在,可以使用Open命令打开继续使用,只有调用Deallocate语句才会完全释放

?游标实例:

????????????Declare MyCusror Cursor Scroll

??????????????????For Select * From Master_Goods Order By GoodsID

????????????Open MyCursor

????????????Fetch next From MyCursor
????????????Into @GoodsCode,@GoodsName

????????????While(@@Fetch_Status = 0)
??????????????????Begin

?????????????????????????Begin
???????????????????????????????Select @GoodsCode = Convert(Char(20),@GoodsCode)
???????????????????????????????Select @GoodsName = Convert(Char(20),@GoodsName)
???????????????????????????????PRINT @GoodsCode + ':' + @GoodsName
?????????????????????????End

?????????????????????????Fetch next From MyCursor
?????????????????????????Into @GoodsCode,@GoodsName

??????????????????End ????????????Close MyCursor ????????????Deallocate MyCursor

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读