微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

sqlserver 游标使用

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

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

相关推荐