zoukankan      html  css  js  c++  java
  • 游标使用

    (一),认识游标(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
  • 相关阅读:
    Emit介绍【转】
    在.NET中使用反射实现简易插件机制【转】
    RabbitMQ笔记-Qos与消息应答
    Http级别缓存助手类(ASP.Net Core)
    实现一个迷你IOC容器
    使用CMake在Windows环境下的VS2019中配置openCV
    如何在Visual Studio 2019中启动并配置一个使用pyTorch的C++项目(Windows系统,CMAKE项目)
    windows环境下使用python中tensorflow的tensorboard功能无法创建指定路径的问题
    使用python的selenium库自动填写网页(疫情每日一报)
    十进制转换二进制toBinaryString源码分析
  • 原文地址:https://www.cnblogs.com/xiaoliu66007/p/5870834.html
Copyright © 2011-2022 走看看