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
  • 相关阅读:
    API函数ShellExecute与ShellExecuteEx用法
    C#txt文本分割器
    Python异常处理
    python bs4解析网页时 bs4.FeatureNotFound: Couldn't find a tree builder with the features you requested: lxml. Do you need to inst(转)
    gensim中TaggedDocument 怎么使用
    Python读取文件时出现UnicodeDecodeError: 'gbk' codec can't decode byte 0x80 in position xx: 解决方案
    收集python2代码转python3遇到的问题
    互联网浪潮之下,聊聊 90 后所面临的困境
    互联网公司里都有哪些潜规则?
    大厂程序员的一天是如何度过的?
  • 原文地址:https://www.cnblogs.com/xiaoliu66007/p/5870834.html
Copyright © 2011-2022 走看看