SQL Server游标使用快速上手

时间:2020-12-04 13:25:51

使用游标有四种基本的步骤:声明游标、打开游标、提取数据、关闭游标

如下面SQL示例所示:

SQL Server游标使用快速上手
-- =============================================
--
Author:        <搏击的小船>
--
Create date: <2011-04-19>
--
Description:    <SQL SERVER 游标DEMO>
--
=============================================

-- 临时表
CREATE TABLE ##TempTB
(
ID
INT IDENTITY ,
ColA
VARCHAR ( 50 ),
ColB
VARCHAR ( 50 )
)
DECLARE @i INT = 0 ;
WHILE ( @i < 10 )
BEGIN
   
INSERT INTO ##TempTB
            (ColA, ColB )
   
VALUES   (
             
' 测试字段ColA ' + CAST ( @i AS VARCHAR ( 10 ))
              ,
             
' 测试字段ColB ' + CAST ( @i AS VARCHAR ( 10 ))
              )             
        
SET @i = @i + 1 ;
END
--SELECT * FROM ##TempTB;



-- 定义3个变量来接收游标遍历的值
DECLARE @a VARCHAR ( 50 ),
       
@b VARCHAR ( 50 ),
       
@c VARCHAR ( 50 );

-- 申明游标并填充数据
DECLARE cur CURSOR FOR SELECT * FROM ##TempTB
-- 打开游标
OPEN cur
-- 取下一条数据填充
FETCH NEXT FROM cur INTO @a , @b , @c
SELECT @a , @b , @c ;
-- @@FETCH_STATUS |  0 提取成功; 1语句失败或行不在结果集中;2提取的行不存在
WHILE ( @@FETCH_STATUS = 0 )
BEGIN
   
-- to do sth//
    FETCH NEXT FROM cur INTO @a , @b , @c ;
   
SELECT @a , @b , @c ;   
END    
-- 关闭游标
CLOSE cur
-- 删除游标资源
DEALLOCATE cur   

DROP TABLE ##TempTB;