论坛首页 综合技术论坛

存储过程中游标的使用

浏览 12882 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2007-05-01  

      游标分为动态游标与静态游标,在本文中只是讲述一下,我在使用动态游标的一点心得,至于游标定义使用具体操作在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 所述

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

论坛首页 综合技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics