游标使用

(一),认识游标(cursor)
就是一个可读的标识,用来标识数据取到什么地方了。
(二),游标特性
1,只读
2,不滚动
3,不敏感的
(三),使用游标
需要强调的是,游标必须在定义处理程序之前被定义,但变量必须在定义游标之前被定义,顺序就是变量定义-游标定义-处理程序。
1.定义游标
DECLARE cursor_name CURSOR FOR select_statement
这个语句声明一个游标。也可以在子程序中定义多个游标,一个块中的每一个游标必须命名唯一。声明游标后也是单条操作的。
2. 游标OPEN
OPEN cursor_name
这个语句打开先前声明的游标。
3. 游标FETCH
FETCH cursor_name INTO var_name [, var_name] ...
这个语句用指定的打开游标读取下一行(如果有下一行的话),并且前进游标指针至该行。
4. 游标CLOSE
CLOSE cursor_name
这个语句关闭先前打开的游标,注意,用完后必须关闭。

写法1:

BEGIN
    DECLARE done INT DEFAULT 0;
    DECLARE tmpid int;

    DECLARE mycursor CURSOR FOR SELECT  id from t_b_px_circle_info;
    DECLARE CONTINUE HANDLER FOR NOT FOUND SET done=1;

    OPEN mycursor;

    REPEAT 
        FETCH mycursor INTO tmpid;
        IF NOT done THEN
            INSERT into t_b_px_circle_zan(t_b_px_circle_info_id,t_u_user_id,is_see,createdate)
                        SELECT tmpid,u.id,1,now()
                        FROM t_u_user  u
                        INNER JOIN (SELECT u2.id,u2.phone from t_u_user u2 WHERE u2.phone='123')u2 on u2.id = u.id
                        WHERE u.id >= (1999 * RAND() + 1329)  
                        LIMIT 34,2;
        END IF;

    UNTIL done END REPEAT;

    CLOSE mycursor;

END

写法2:

DECLARE @UserId varchar(50) 
DECLARE My_Cursor CURSOR --定义游标
FOR (SELECT UserId FROM dbo.MemberAccount) --查出需要的集合放到游标中
OPEN My_Cursor; --打开游标
FETCH NEXT FROM My_Cursor INTO @UserId; --读取第一行数据(将MemberAccount表中的UserId放到@UserId变量中)
WHILE @@FETCH_STATUS = 0
    BEGIN
        PRINT @UserId; --打印数据(打印MemberAccount表中的UserId)
        UPDATE dbo.MemberService SET ServiceTime = DATEADD(Month, 6, getdate()) WHERE UserId = @UserId; --更新数据
        FETCH NEXT FROM My_Cursor INTO @UserId; --读取下一行数据(将MemberAccount表中的UserId放到@UserId变量中)
    END
CLOSE My_Cursor; --关闭游标
DEALLOCATE My_Cursor; --释放游标
GO
View Code
原文地址:https://www.cnblogs.com/xiaoliu66007/p/5870834.html