欢迎来到站长天空!

其它数据库

当前位置: 主页 > 数据库 > 其它数据库

mysql游标的原理与用法实例分析

时间:2025-12-11 20:00:02|栏目:其它数据库|点击:

本文实例讲述了mysql游标的原理与用法。分享给大家供大家参考,具体如下:

本文内容:

什么是游标 创建游标 使用游标

首发日期:2018-04-18


什么是游标:

如果你前面看过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;

上面的代码会有一个报错mysql游标的原理与用法实例分析,不断循环的话,始终会达到表的末尾,到了末尾就无法继续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;

更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL查询技巧大全》、《MySQL事务操作技巧汇总》、《MySQL存储过程技巧大全》、《MySQL数据库锁相关技巧汇总》及《MySQL常用函数大汇总》

希望本文所述对大家MySQL数据库计有所帮助。

上一篇:Win10安装MySQL8压缩包版的教程

栏    目:其它数据库

下一篇:mysql数据库常见基本操作实例分析【创建、查看、修改及删除数据库】

本文标题:mysql游标的原理与用法实例分析

本文地址:https://zz.feitang.co/shujuku/30154.html

广告投放 | 联系我们 | 版权申明

申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:257218569 | 邮箱:257218569@qq.com

Copyright © 2018-2025 站长天空 版权所有 Powered by EyouCms冀ICP备14023439号