分类: 数据库开发技术
2012-11-15 23:12:33
游标分为动态游标与静态游标,在本文中只是讲述一下,我在使用动态游标的一点心得,至于游标定义使用具体操作在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 所述
总之,在动态游标的情况下,基表变化后会马上影响到游标结果集,至于能不能马上读出这种变化,就要看具体的游标声明语句
本文出自: