mysql游标的作用是什么

本篇文章“mysql游标的作用是什么”主要为您从以下几个方面讲解:实例、游标嵌套、游标的用法、动态SQL,希望对您有所启发。

本篇文章“mysql游标作用什么”主要为您从以下几个方面讲解:实例、游标嵌套、游标的用法、动态SQL,希望对您有所启发。

mysql游标的作用是什么

在mysql中,游标有指针的作用,主要用于对查询数据库所返回的记录结果集进行遍历,以便进行相应的操作。 游标实际上是一种能从包括多条数据记录的结果集中每次提取一条记录的机制。关系数据库管理系统实质是面向集合的,在MySQL中并没有一种描述表中单一记录的表达形式,除非使用WHERE子句来限制只有一条记录被选中;所以有时必须借助于游标来进行单条记录的数据处理。

本教程操作环境:windows7系统、mysql8版本、Dell G3电脑。

MySQL游标(Cursor)

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

游标充当指针的作用。

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

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

关系数据库管理系统实质是面向集合的,在 MySQL 中并没有一种描述表中单一记录的表达形式,除非使用 WHERE 子句来限制只有一条记录被选中。所以有时我们必须借助于游标来进行单条记录的数据处理。

一般通过游标定位到结果集的某一行进行数据修改。

游标的用法

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

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

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

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

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

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

实例

-  BEGIN    --定义变量  declare testrangeid BIGINT;  declare versionid BIGINT;   declare done int;  --创建游标,并存储数据  declare cur_test CURSOR for      select id as testrangeid,version_id as versionid from tp_testrange;  --游标中的内容执行完后将done设置为1   DECLARE CONTINUE HANDLER FOR NOT FOUND SET done=1;   --打开游标  open cur_test;  --执行循环    posLoop:LOOP  --判断是否结束循环          IF done=1 THEN          LEAVE posLoop;      END IF;   --取游标中的值      FETCH  cur_test into testrangeid,versionid;  --执行更新操作      update tp_data_execute set version_id=versionid where testrange_id = testrangeid;    END LOOP posLoop;  --释放游标  CLOSE cur_test;    END  -

例子2:

我们现在要用存储过程做一个功能,统计iphone的总库存是多少,并把总数输出到控制台。

--在windows系统中写存储过程时,如果需要使用declare声明变量,需要添加这个关键字,否则会报错。  delimiter //  drop procedure if exists StatisticStore;  CREATE PROCEDURE StatisticStore()  BEGIN      --创建接收游标数据的变量      declare c int;      declare n varchar(20);      --创建总数变量      declare total int default 0;      --创建结束标志变量      declare done int default false;      --创建游标      declare cur cursor for select name,count from store where name = 'iphone';      --指定游标循环结束时的返回值      declare continue HANDLER for not found set done = true;      --设置初始值      set total = 0;      --打开游标      open cur;      --开始循环游标里的数据      read_loop:loop      --根据游标当前指向的一条数据      fetch cur into n,c;      --判断游标的循环是否结束      if done then          leave read_loop;    --跳出游标循环      end if;      --获取一条数据时,将count值进行累加操作,这里可以做任意你想做的操作,      set total = total + c;      --结束游标循环      end loop;      --关闭游标      close cur;        --输出结果      select total;  END;  --调用存储过程  call StatisticStore();

fetch是获取游标当前指向的数据行,并将指针指向下一行,当游标已经指向最后一行时继续执行会造成游标溢出。
使用loop循环游标时,他本身是不会监控是否到最后一条数据了,像下面代码这种写法,就会造成死循环;

read_loop:loop  fetch cur into n,c;  set total = total+c;  end loop;

在MySql中,造成游标溢出时会引发mysql预定义的NOT FOUND错误,所以在上面使用下面的代码指定了当引发not found错误时定义一个continue 的事件,指定这个事件发生时修改done变量的值。

declare continue HANDLER for not found set done = true;

所以在循环时加上了下面这句代码:

--判断游标的循环是否结束  if done then      leave read_loop;    --跳出游标循环  end if;

如果done的值是true,就结束循环。继续执行下面的代码

使用方式

游标有三种使用方式:

  • 第一种就是上面的实现,使用loop循环;
  • 第二种方式如下,使用while循环:
drop procedure if exists StatisticStore1;  CREATE PROCEDURE StatisticStore1()  BEGIN      declare c int;      declare n varchar(20);      declare total int default 0;      declare done int default false;      declare cur cursor for select name,count from store where name = 'iphone';      declare continue HANDLER for not found set done = true;      set total = 0;      open cur;      fetch cur into n,c;      while(not done) do          set total = total + c;          fetch cur into n,c;      end while;            close cur;      select total;  END;    call StatisticStore1();

第三种方式是使用repeat执行:

drop procedure if exists StatisticStore2;  CREATE PROCEDURE StatisticStore2()  BEGIN      declare c int;      declare n varchar(20);      declare total int default 0;      declare done int default false;      declare cur cursor for select name,count from store where name = 'iphone';      declare continue HANDLER for not found set done = true;      set total = 0;      open cur;      repeat      fetch cur into n,c;      if not done then          set total = total + c;      end if;      until done end repeat;      close cur;      select total;  END;    call StatisticStore2();

游标嵌套

在mysql中,每个begin end 块都是一个独立的scope区域,由于MySql中同一个error的事件只能定义一次,如果多定义的话在编译时会提示Duplicate handler declared in the same block。

drop procedure if exists StatisticStore3;  CREATE PROCEDURE StatisticStore3()  BEGIN      declare _n varchar(20);      declare done int default false;      declare cur cursor for select name from store group by name;      declare continue HANDLER for not found set done = true;      open cur;      read_loop:loop      fetch cur into _n;      if done then          leave read_loop;      end if;      begin          declare c int;          declare n varchar(20);          declare total int default 0;          declare done int default false;          declare cur cursor for select name,count from store where name = 'iphone';          declare continue HANDLER for not found set done = true;          set total = 0;          open cur;          iphone_loop:loop          fetch cur into n,c;          if done then              leave iphone_loop;          end if;          set total = total + c;          end loop;          close cur;          select _n,n,total;      end;      begin              declare c int;              declare n varchar(20);              declare total int default 0;              declare done int default false;              declare cur cursor for select name,count from store where name = 'android';              declare continue HANDLER for not found set done = true;              set total = 0;              open cur;              android_loop:loop              fetch cur into n,c;              if done then                  leave android_loop;              end if;              set total = total + c;              end loop;              close cur;          select _n,n,total;      end;      begin            end;      end loop;      close cur;  END;    call StatisticStore3();

上面就是实现一个嵌套循环,当然这个例子比较牵强。凑合看看就行。

动态SQL

Mysql 支持动态SQL的功能

set @sqlStr='select * from table where condition1 = ?';  prepare s1 for @sqlStr;  --如果有多个参数用逗号分隔  execute s1 using @condition1;  --手工释放,或者是 connection 关闭时, server 自动回收  deallocate prepare s1;

本文有关“mysql游标的作用是什么”的介绍就到这里,如果您已经掌握上述知识,那就赶紧行动实操一下!如果还需要了解更多“mysql游标的作用是什么”相关内容,可点击进入Worktile网站相关频道,进行搜索与查询。

文章标题:mysql游标的作用是什么,发布者:亿速云,转载请注明出处:https://worktile.com/kb/p/15081

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022年6月29日 上午3:03
下一篇 2022年6月29日 上午3:37

相关推荐

  • win server2012 r2服务器共享文件夹怎么设置

    1.启用guest账号 控制面板->用户账户->管理其他账户->Guest启用 2.设置共享%ignore_a_1% 添加everyone和Guest 点击共享 点击网络和共享中心 关闭密码保护共享 3.策略中找到 网络访问->本地帐户的共享和安全模型”并双击,会弹出其属性窗…

    2022年9月24日
    20700
  • vue-router中children怎么使用

    关于children的使用 children的使用场景 比如页面左侧显示菜单,右侧显示不同菜单下的内容,类似如下element网站,那么右侧部分的内容就是当前页面的children 存在如下场景,点击导航一跳转至页面1,导航二跳转页面2,且页面1中存在子页面 路由js如下: const routes…

    2022年8月30日
    15800
  • 如何解决mysql深分页问题

    日常需求开发过程中,相信大家对于limit一定不会陌生,但是使用limit时,当偏移量(offset)非常大时,会发现查询效率越来越慢。一开始limit 2000时,可能200ms,就能查询出需要的到数据,但是当limit 4000 offset 100000时,会发现它的查询效率已经需要1S左右,…

    2022年9月13日
    36300
  • Android开发使用strings.xml多语言翻译的方法是什么

    概述 在实际项目开发中如果需要支持多语言,我们需要整理项目中所有的字符串并翻译成对应的语种放在相应的文件夹下,就像这样 最让我们头痛的是我们得一条一条的复制粘贴这些翻译文本到对应语种文件夹下的string.xml文件中,这种重复性的工作浪费了大量的开发时间。针对这个问题网上也有很多的解决方案比如An…

    2022年9月24日
    18600
  • windows会声会影x5如何导出视频

    会声会影x5导出视频的方法 1、我们可以在界面的左上角或者上方找到“分享”按钮,点击它。 2、然后选择想要导出的方式,一般我们选择“创建视频文件”。 3、然后我们点击如图“创建视频文件”可以选择视频的格式。 4、这里我们选择mp4格式(大家可以根据需要自行选择),然后还可以选择更细致的格式。 5、选…

    2022年9月15日
    8400
  • 同时利用多个僵尸网络攻击目标的示例分析

    APT33常以石油和航空业为攻击目标,最近的调查结果显示,该组织一直在使用大约12台经过多重混淆的C&C服务器来攻击特定目标。该组织主要在中东、美国和亚洲地区开展的针对性极强的恶意攻击活动。 每一个僵尸网络由12台以上受感染的计算机组成,用来攻击的恶意软件只有基本的功能,包括下载和运行其他恶…

    2022年9月18日
    7500
  • mysql如何删除表的一行数据

    在mysql中,可以使用DELETE语句配合WHERE子句和LIMIT子句来删除表的一行数据,语法为“DELETE FROM 表名 WHERE 删除条件 LIMIT 1;”;DELETE语句用于删除表中一行或者多行数据,而WHERE子句用于设置删除条件,LIMIT子句用于设置删除数据的行数。 本教程…

    2022年9月21日
    33100
  • weblogic攻击手法有哪些

    简介 weblogic服务器的特点为架构庞大复杂,蓝队一般很难防御,且多部署于外网。而且weblogic的攻击成本比较低,只要存在漏洞,一般可以直接获取目标服务器的root权限。在攻防演习中被各大攻击队,防守方重点关注。 当然,目前网上公开的各种exp程序,当然也包括我自己的工具,或多或少都有点问题…

    2022年9月22日
    7700
  • word怎么添加页码

    word加页码的方法: 1、说先进入word文档,然后点击菜单中的“插入”选项。 2、然后在下拉的菜单中选择”页码“选项。 3、然后就会出现页码的设置框,可以点击“格式”来进行编辑。 4、然后你就可以在数字格式的模式进行格式选择,然后点击确定。 5、当你全部设置完成之后可以直接点击确定来完成设置。 …

    2022年9月20日
    9000
  • jmeter正则表达式提取器怎么使用

    使用方法 1,把正则表达式添加到需要提取返回内容的http请求里,添加步骤是,,右键http请求–添加–后置处理器–正则表达式处理器 2,在正则表达式提取器配置设置页里, 1)要检查的响应字段:相当于是要提取哪个位置的内容数据 2)引用名称:我们把内容提取出来后要…

    2022年9月21日
    16300
联系我们
站长微信
站长微信
分享本页
返回顶部