mysql的游标怎么使用

使用游标(cursor)

1.声明游标

DECLARE cursor_name CURSOR FOR select_statement
这个语句声明一个游标。也可以在子程序中定义多个游标,但是一个块中的每一个游标必须有唯一的名字。声明游标后也是单条操作的,但是不能用SELECT语句不能有INTO子句。

2. 游标OPEN语句

OPEN cursor_name
这个语句打开先前声明的游标。

3. 游标FETCH语句

FETCH cursor_name INTO var_name [, var_name] ...
这个语句用指定的打开游标读取下一行(如果有下一行的话),并且前进游标指针。

4. 游标CLOSE语句

CLOSE cursor_name
这个语句关闭先前打开的游标。

例1

 代码如下 复制代码

//建立表结构
create table person(name varchar(10));

insert into person values(¹a¹);
insert into person values(¹b¹);
insert into person values(¹c¹);
insert into person values(¹d¹);
insert into person values(¹e¹);

//初始化
drop procedure if exists  cursorTest  

//建立
CREATE PROCEDURE cursorTest()
    BEGIN

 //定义变量
         declare name1 varchar(10) default ¹¹ ;
         declare name2 varchar(100) default ¹¹ ;

         declare mycursor CURSOR FOR select name from person;

         declare CONTINUE HANDLER FOR SQLSTATE ¹02000¹ SET tmpname = null;

 //打开游标
 OPEN mycursor;

 //遍历游标
 FETCH mycursor INTO name1;

 //把游标查询出的 name 都加起并用 ; 号隔开
 WHILE( name1 is not null) DO
  set name1 = CONCAT(name1, ";") ;
  set name2 = CONCAT(name2, name1) ;
  FETCH mycursor INTO name1;
 END WHILE;
 CLOSE mycursor;

 select mycursor;
    END;

//调用游标
call mycursor()

运行结果:

mysql> call mycursor()
+--------------------------------------+

| name2                                |

+--------------------------------------+

| a;b;c;d;e;                           |

+--------------------------------------+

1 row in set (0.01 sec)

例2

一个完整的例子:

 

 代码如下 复制代码

  -- 定义本地变量

    DECLARE o varchar(128);

   -- 定义游标

   DECLARE ordernumbers CURSOR

   FOR

   SELECT callee_name FROM account_tbl where acct_timeduration=10800;

   DECLARE CONTINUE HANDLER FOR NOT FOUND SET no_more_departments=1;

   SET no_more_departments=0;

  
   -- 打开游标

   OPEN ordernumbers;

   -- 循环所有的行

   REPEAT

       -- Get order number

      FETCH ordernumbers INTO o;

      update account set allMoney=allMoney+72,lastMonthConsume=lastMonthConsume-72 where NumTg=@o;
    
    
  -- 循环结束

      UNTIL no_more_departments
     END REPEAT;

   -- 关闭游标

   CLOSE ordernumbers;

游标(cursor)的特性

1,只读的,不能更新的。
2,不滚动的
3,不敏感的,不敏感意为服务器可以活不可以复制它的结果表

游标(cursor)必须在声明处理程序之前被声明,并且变量和条件必须在声明游标或处理程序之前被声明

时间: 2024-09-14 09:14:12

mysql的游标怎么使用的相关文章

mysql Cursor游标参考手册

mysql教程 Cursor游标定义 DECLARE cursor_name CURSOR FOR SELECT_statement; 游标操作 OPEN 打开游标 OPEN cursor_name; FETCH 获取游标当前指针的记录,并传给指定变量列表,注意变量数必须与MySQL游标返回的字段数一致,要获得多行数据,使用循环语句去执行FETCH FETCH cursor_name INTO variable list; CLOSE关闭游标 CLOSE cursor_name ; 注意:MyS

mysql存储过程 游标 循环使用介绍_Mysql

Mysql的存储过程是从版本5才开始支持的,所以目前一般使用的都可以用到存储过程.今天分享下自己对于Mysql存储过程的认识与了解. 一些简单的调用以及语法规则这里就不在赘述,网上有许多例子.这里主要说说大家常用的游标加循环的嵌套使用. 首先先介绍循环的分类: (1)WHILE ... END WHILE (2)LOOP ... END LOOP (3)REPEAT ... END REPEAT (4)GOTO 这里有三种标准的循环方式:WHILE循环,LOOP循环以及REPEAT循环.还有一种

Mysql的游标的定义使用及关闭深入分析_Mysql

Mysql从5.0开始支持存储过程和trigger,给我们喜欢用mysql的朋友们更喜欢mysql的理由了,语法上和PL/SQL有差别,不过搞过编程的人都知道,语法不是问题,关键是思想,大致了解语法后,就从变量定义,循环,判断,游标,异常处理这个几个方面详细学习了.关于游标的用法Mysql现在提供的还很特别,虽然使用起来没有PL/SQL那么顺手,不过使用上大致上还是一样, 定义游标 declare fetchSeqCursor cursor for select seqname, value f

MySQL使用游标批量处理进行表操作_Mysql

一.概述 本章节介绍使用游标来批量进行表操作,包括批量添加索引.批量添加字段等.如果对存储过程.变量定义.预处理还不是很熟悉先阅读我前面写过的关于这三个概念的文章,只有先了解了这三个概念才能更好的理解这篇文章. 理解MySQL变量和条件:http://www.jb51.net/article/81375.htm 理解Mysql prepare预处理语句:http://www.jb51.net/article/81378.htm 理解MySQL存储过程和函数:http://www.jb51.net

MySQL存储过程游标操作的跳出与继续

最近遇到这样的问题,在MySQL的存储过程中,游标操作时,需要执行一个conitnue的操作.众所周知,MySQL中的游标循环操作常用的有三种,LOOP,REPEAT,WHILE.三种循环,方式大同小异.以前从没用过,所以记下来,方便以后查阅. 1.REPEAT  代码如下 复制代码 REPEAT     Statements;   UNTIL expression END REPEAT demo DECLARE num INT; DECLARE my_string  VARCHAR(255);

mysql cursor 游标

cursor 1.  declare     eg: declare c1 cursor for ....(sql select salary from employees;)      declare <游标名> cursor for <select语句>; 2.  open     eg: open c1;     open <游标名>; 3.  operation    eg: loop            fetch c1 into a;         en

mysql动态游标学习(mysql存储过程游标)_Mysql

复制代码 代码如下: -- 建立测试表和数据create table webuser (username varchar(10));insert into webuser values ('a1'),('a2'),('a3'),('b1'),('b2'),('b3');commit; -- 建立存储过程drop procedure if exists dynamic_cursor;delimiter //CREATE PROCEDURE dynamic_cursor (IN p_name var

Mysql存储过程中游标的用法实例_Mysql

本文实例讲述了Mysql存储过程中游标的用法.分享给大家供大家参考.具体如下: 1. 批量插入商户路由关联数据: DELIMITER $$ USE `mmm_mac`$$ DROP PROCEDURE IF EXISTS `批量插入商户路由关联数据`$$ CREATE DEFINER=`root`@`%` PROCEDURE `批量插入商户路由关联数据`() BEGIN DECLARE v_partner_no VARCHAR(32); DECLARE v_partner_id INT(11);

mysql 学习笔记

以前主要使用oracle做数据库,现在换成mysql了,发现不一样的地方还是挺多的,记录一下:  一.centos上的yum install方式安装   完全卸载(可选,如果之前安装了旧版本) a) rpm -qa|grep mysql  先查看是否已经安装了mysql  b) yum remove mysql* 执行完成后,再执行下a)中的命令确认下  c)  rm -f /etc/my.cnf rm -f /etc/my.cnf.rmp* rm -rf /var/lib/mysql    安