锁定老帖子 主题:存储过程中游标的使用
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2007-05-01
游标分为动态游标与静态游标,在本文中只是讲述一下,我在使用动态游标的一点心得,至于游标定义使用具体操作在SQL server帮助中可以查询。 在创建一个游标,目的是为了读取基表A中的test字段的值并把该值插入到一个临时表temp中,在循环读取游标中的值并把插入到临时表的时候,这时候对基表有插入操作,那么新插入的纪录能不能动态的加入到游标中呢?能不能马上看到这种变化呢? 存储过程:
CREATE PROCEDURE TEST DECLARE T CURSOR FOR SELECT TEST FROM A ORDER BY TEST SELECT * FROM #TEMP 下面分一下几种情况具体分析: 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 所述 总之,在动态游标的情况下,基表变化后会马上影响到游标结果集,至于能不能马上读出这种变化,就要看具体的游标声明语句 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
浏览 12882 次