一聚教程网:一个值得你收藏的教程网站

最新下载

热门教程

mysql游标的原理与用法代码实例解析

时间:2020-04-13 编辑:袖梨 来源:一聚教程网

本篇文章小编给大家分享一下mysql游标的原理与用法代码实例解析,对大家的学习有一定的帮助,小编觉得挺不错的,现在分享给大家供大家参考,有需要的小伙伴们可以来看看。

什么是游标:

如果你前面看过mysql函数,会发现无法使用返回多行结果的语句。但如果你又确实想要使用时,就需要使用到游标,游标可以帮你选择出某个结果(这样就可以做到返回单个结果)。

另外,使用游标也可以轻易的取出在检索出来的行中前进或后退一行或多行的结果。

游标可以遍历返回的多行结果。

补充:

Mysql中游标只适用于存储过程以及函数。

创建游标:

语法:

1.定义游标:declare 游标名 cursor for select语句;

2.打开游标:open 游标名;

获取结果:fetch 游标名 into 变量名[,变量名];

关闭游标:close 游标名;

create procedure p1()
begin
  declare id int;
  declare name varchar(15);
  -- 声明游标
  declare mc cursor for select * from class;
  -- 打开游标
  open mc;
  -- 获取结果
  fetch mc into id,name;
  -- 这里是为了显示获取结果
  select id,name;
  -- 关闭游标
  close mc;
  
end;
create procedure p2()
begin
  declare id int;
  declare name varchar(15);
  -- 声明游标
  declare mc cursor for select * from class;
  -- 打开游标
  open mc;
  -- 获取结果
  loop -- 循环,将表的内容都转移到class2中
  fetch mc into id,name;
  -- 这里是为了显示获取结果
  insert into class2 values(id,name);
  -- 关闭游标
  end loop;
  close mc;
  
end;

使用游标:

游标每一次fetch都是获取一行结果,可以使用变量来获取fetch到的每一列的值

create procedure p2()
begin
  declare id int;
  declare name varchar(15);
  -- 声明游标
  declare mc cursor for select * from class;
  -- 打开游标
  open mc;
  -- 获取结果
  loop -- 循环,将表的内容都转移到class2中
  fetch mc into id,name;
  -- 这里是为了显示获取结果
  insert into class2 values(id,name);
  -- 关闭游标
  end loop;
  close mc;
  
end;

上面的代码会有一个报错,不断循环的话,始终会达到表的末尾,到了末尾就无法继续fetch,一般来说都要避免报错,到了末尾前会有一个mysql定义的

create procedure p3()
begin
  declare id int;
  declare name varchar(15);
  declare flag int default 0;
  -- 声明游标
  declare mc cursor for select * from class;
  declare continue handler for not found set flag = 1;
  -- 打开游标
  open mc;
  -- 获取结果
  l2:loop 
  
  fetch mc into id,name;
  if flag=1 then -- 当无法fetch会触发handler continue
    leave l2;
  end if;
  -- 这里是为了显示获取结果
  insert into class2 values(id,name);
  -- 关闭游标
  end loop;
  close mc;
  
end;

call p3();-- 不报错
select * from class2;

热门栏目