SQLServer2005数据库游标调用函数的使用方法

发布时间:2021-08-18 11:58:14 作者:chen
来源:亿速云 阅读:139

这篇文章主要讲解了“SQLServer2005数据库游标调用函数的使用方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“SQLServer2005数据库游标调用函数的使用方法”吧!

  1、建立基表

  createtableplanwork(planidint,empidint)insertintoplanworkvalues(1,100)insertintoplanworkvalues(2,200)insertintoplanworkvalues(3,300)insertintoplanworkvalues(4,400)insertintoplanworkvalues(5,500)insertintoplanworkvalues(6,600)insertintoplanworkvalues(7,700)insertintoplanworkvalues(8,800)select*fomplanwork

  2、建立函数

  dropfunctionfindworkplancreatefunctionfindworkplan(@numint)returnsintasbegindeclare@eidintset@eid=(selectempidfromplanworkwhereplanid=@num)return@eid;end;

  3、测试函数

  selectdbo.findworkplan(3)

  SQLServer2005数据库游标调用函数怎么使用

  4、利用游标调用函数

  4.1、创建一个表,利用这个表里面的数值得到workplan表里面对应的empno

  createtablexb_test1(xidint)insertintoxb_test1values(1)insertintoxb_test1values(2)insertintoxb_test1values(3)insertintoxb_test1values(4)insertintoxb_test1values(5)insertintoxb_test1values(6)insertintoxb_test1values(7)insertintoxb_test1values(8)select*fromxb_test1

  4.2、只能用循环遍历xb_test1表分别找出对应表workplan的empno,考虑到需遍历整个xb_test1表,所以决定用游标,不知道用oracle的with函数怎么样?该WHILE结构测试用于游标的函数@@FETCH_STATUS的返回值。因为@@FETCH_STATUS可能返回–2、-1或0,所以,所有的情况都应进行测试。假如某一行在开始执行此存储过程以后从游标结果中删除,将跳过该行。成功提取(0)后将执行BEGIN...END循环内部的SELECT语句。

  declareempno_cursorcursorforselectxidfromxb_test1openempno_cursordeclare@aint,@resultintfetchnextfromempno_cursorinto@awhile(@@fetch_status<>-1)beginif(@@fetch_status<>-2)begin--print@aset@result=(selectdbo.findworkplan(@a))print@resultendfetchnextfromempno_cursorinto@aendcloseempno_cursordeallocateempno_cursor。

感谢各位的阅读,以上就是“SQLServer2005数据库游标调用函数的使用方法”的内容了,经过本文的学习后,相信大家对SQLServer2005数据库游标调用函数的使用方法这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

推荐阅读:
  1. 游标
  2. Oracle 游标

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

sqlserver2005 数据库

上一篇:如何使用CSS3制作一个简单页面的布局

下一篇:易语言如何实现机读文本软件

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》