您好,欢迎访问一九零五行业门户网

mysql的游标怎么使用

个人觉得就是一个cursor,就是一个标识,用来标识数据取到什么地方了。你也可以把它理解成数组中的下标。。
使用游标(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)必须在声明处理程序之前被声明,并且变量和条件必须在声明游标或处理程序之前被声明
其它类似信息

推荐信息