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

本文实例讲述了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;

上面的代码会有一个报错

9a3e17691029d8ee7d735703682a7da6.png,不断循环的话,始终会达到表的末尾,到了末尾就无法继续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数据库计有所帮助。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值