数据库游标的使用

这里的例子是仅在mysql中执行的,跟任何框架框架都没有关系

游标的使用案例

当前有三张表A、B、C其中A和B是一对多关系,B和C是一对多关系,现在需要将B中A表的主键存到C中;

常规思路就是将B中查询出来然后通过一个update语句来更新C表就可以了,但是B表中有2000多条数据,

难道要执行2000多次?显然是不现实的;最终找到写一个存储过程然后通过循环来更新C表,

然而存储过程中的写法用的就是游标的形式。

个人理解:游标可以存储一个结果集,但是在mysql中只有游标可以存储,设置变量是存储不了的。那么在数据量大的时候就需要使用循环来操作,所有这里就只能使用游标来获取字段值进行循环,游标一次可以获取一行值

简介

游标实际上是一种能从包括多条数据记录的结果集中每次提取一条记录的机制。

游标充当指针的作用。

尽管游标能遍历结果中的所有行,但他一次只指向一行。

游标的作用就是用于对查询数据库所返回的记录进行遍历,以便进行相应的操作。

用法

一、声明一个游标: declare 游标名称 CURSOR for table;(这里的table可以是你查询出来的任意集合)

二、打开定义的游标:open 游标名称;

三、获得下一行数据:FETCH 游标名称 into testrangeid,versionid;

四、需要执行的语句(增删改查):这里视具体情况而定

五、释放游标:CLOSE 游标名称;

注:mysql存储过程每一句后面必须用;结尾,使用的临时字段需要在定义游标之前进行声明。

实例

create procedure user_data(out count int)

begin

declare user_id int default 1;

-- 游标标识

declare blag int default 1;

-- 游标

declare user_cursor cursor for select data.user_id from mac_user as data;

-- 处理not fount的异常

declare continue handler for not found set blag = 0;

set count := 0;

-- 打开游标

open user_cursor;

-- 执行循环

read_loop:loop

-- 获取游标中的值

fetch user_cursor into user_id;

-- 检测循环是否

if blag = 0 then

-- 跳出循环

leave read_loop;

end if;

-- if user_id = 1 then

set count = count + user_id;

-- end if;

end loop read_loop;

-- 关闭游标

close cur;

end;

call user_data(@count);

select @count;

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20190724A0D1S700?refer=cp_1026
  • 腾讯「云+社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 yunjia_community@tencent.com 删除。

扫码关注云+社区

领取腾讯云代金券