Chinaunix首页 | 论坛 | 博客
  • 博客访问: 12427408
  • 博文数量: 187
  • 博客积分: 7517
  • 博客等级: 少将
  • 技术积分: 1981
  • 用 户 组: 普通用户
  • 注册时间: 2007-05-20 18:51
文章分类

全部博文(187)

文章存档

2015年(3)

2013年(4)

2012年(20)

2011年(2)

2010年(96)

2009年(14)

2008年(47)

2007年(1)

我的朋友

分类: 数据库开发技术

2012-11-15 23:12:33

SQL SERVER 在存储过程中游标的使用  

 

 游标分为动态游标与静态游标,在本文中只是讲述一下,我在使用动态游标的一点心得,至于游标定义使用具体操作在SQL server帮助中可以查询。

     在创建一个游标,目的是为了读取基表A中的test字段的值并把该值插入到一个临时表temp中,在循环读取游标中的值并把插入到临时表的时候,这时候对基表有插入操作,那么新插入的纪录能不能动态的加入到游标中呢?能不能马上看到这种变化呢?

   存储过程:

 

CREATE PROCEDURE TEST

 AS

CREATE TABLE #TEMP

(

    [TEST] [VARCHAR]

)

DECLARE T  CURSOR  FOR SELECT TEST FROM A ORDER BY TEST

DECLARE @NUM  BIGINT

DECLARE @VARINT VARCHAR(50)

--一定要赋初值,不然在循环中@NUM的值不会改变

SELECT @NUM = 0

OPEN T

FETCH NEXT FROM T INTO @VARINT

WHILE @@FETCH_STATUS = 0

BEGIN

    SELECT @NUM = @NUM+1

    INSERT INTO #TEMP VALUES  (@VARINT)

    --在变量等于5的时候插入基表纪录,验证该纪录会不会插入临时表#tenp,从而验证该内容是否动态加入游标

    IF(@NUM = 5)

    INSERT INTO A VALUES('3')

    FETCH NEXT FROM T INTO @VARINT

END

--释放游标

CLOSE T

DEALLOCATE T

SELECT * FROM #TEMP

GO

   下面分一下几种情况具体分析:

1.在上面的存储过程中给游标存入结果集的SQL查询语句中要求按照test字段升序排列,游标指向第五条纪录的时候,插入一条纪录数值为3,肯定也已经加入到了游标的结果集,只是由于结果集是按照test升序排列的,游标指向的当前位置不会改变,所以对于新插入的3 这条纪录是不会加入到临时表中的

2 .如果修改上面存储过程的语句如下:

 DECLARE T  CURSOR  FOR SELECT TEST FROM A

去掉ORDER BY TEST,那么在执行存储过程后会看到新插入的3这条纪录,因为在没有排序的情况下,游标结果集是按照基表顺序来的,在没有定义基表的聚集索引的情况下,插入一条记录到基表,是插入到最后面,这种情况下,新插入的的记录也显示在游标结果集的最后面,那么这种情况下,循环中就可以把信插入基表中的3 这条记录插入到临时表,也就可以显示出来了

3.上面提到聚集索引,在对基表创建聚集索引后,将会影响基表的实际无力存储顺序,所以在这种情况下,如果DECLARE T  CURSOR  FOR SELECT TEST FROM A语句或者DECLARE T  CURSOR  FOR SELECT TEST FROM A ORDER BY TEST情况下都不会看到新插入的3这条记录,原因如2 所述

总之,在动态游标的情况下,基表变化后会马上影响到游标结果集,至于能不能马上读出这种变化,就要看具体的游标声明语句

本文出自: 

  评论这张
转发至微博
转发至微博
0  分享到:        
阅读(106)| 评论(0)| 转载 (0) |举报
历史上的今天
相关文章
最近读者
登录后,您可以在此留下足迹。
评论
点击登录|昵称:
  取消
 
阅读(548) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~