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

    mysql V5.5开始,进行了一次大的改变,就是将InnoDB作为默认的存储引擎。InnoDB支持事务,而且拥有相关的RDBMS特性:ACID事务支持,数据完整性(支持外键),灾难恢复能力等等。
    现在简单总结一下游标的知识。
    (一),认识游标(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

    5.清除游标

    declear cursor_name

    这个语句关闭先前打开的游标,注意,用完后必须关闭。
    (四)示例,下面是一个存储过程,里面用到游标,逐条更新数据(批量更新数据)

    BEGIN
     DECLARE  no_more_record INT DEFAULT 0;
     DECLARE  pID BIGINT(20);
     DECLARE  pValue DECIMAL(15,5);
     DECLARE  cur_record CURSOR FOR   SELECT colA, colB from tableABC;  /*首先这里对游标进行定义*/
     DECLARE  CONTINUE HANDLER FOR NOT FOUND  SET  no_more_record = 1; /*这个是个条件处理,针对NOT FOUND的条件,当没有记录时赋值为1*/
    
     OPEN  cur_record; /*接着使用OPEN打开游标*/
     FETCH  cur_record INTO pID, pValue; /*把第一行数据写入变量中,游标也随之指向了记录的第一行*/
    
     WHILE no_more_record != 1 DO
     INSERT  INTO testTable(ID, Value)
     VALUES  (pID, pValue);
     FETCH  cur_record INTO pID, pValue;
    
     END WHILE;
     CLOSE  cur_record;  /*用完后记得用CLOSE把资源释放掉*/
    END
  • 相关阅读:
    hdu 5112 A Curious Matt (水题)
    hdu 5464 Clarke and problem(dp)
    (2)线程优先级、线程安全
    (1)进程与线程
    并发与并行
    (5) 守护线程与线程阻塞
    java线程中断2
    sleep()和wait()的区别
    java线程中断
    java创建线程的三种方式及其对比
  • 原文地址:https://www.cnblogs.com/tingbogiu/p/5620777.html
Copyright © 2011-2022 走看看