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

相关推荐

  • MyBatisPlus QueryWrapper多条件查询及修改方法是什么

    gt、ge、lt、le、isNull、isNotNull 大于 > 例: gt(“age”, 18) → age > 18 ge 大于等于 >= 例: ge(“age”, 18) → age &gt…

    2022年9月21日
    1.6K00
  • redis缓存延时双删指的是什么

    缓存为啥是删除,而不是更新? 如果是更新,存在分布式事务问题,可能出现修改了缓存,数据库修改失败的情况。只是删除缓存的话,就算数据库修改失败,下次查询会直接取数据库的数据,也不会出现脏数据。 延时双删是什么? 就是在增删改某实体类的时候,要对该实体类的缓存进行清空,清空的位置在数据库操作方法的前后。…

    2022年8月30日
    2.4K00
  • mysql如何修改存储引擎为innodb

    两种修改方法:1、使用SET语句临时修改默认存储引擎,语法为“SET default_storage_engine=innodb;”,当重启客户端后就会恢复为原引擎类型。2、使用ALTER TABLE语句修改,语法“ALTER TABLE 表名 ENGINE=innodb;”,可以修改指定表的引擎类…

    2022年9月21日
    1.2K00
  • 如何进行自动化web渗透测试框架的运用分析

    关于Vajar Vajra是一个自动化的Web渗透测试框架,它可以帮助广大安全研究人员在Web应用程序渗透测试期间自动执行无聊的侦察任务以及针对多个目标的相同扫描。Vajra具有高度可定制特性,允许研究人员自定义扫描范围,我们无需针对目标执行所有的扫描,我们可以根据自己的需要来选择需要执行的扫描任务…

    2022年9月22日
    58200
  • 内核和linux系统的区别有哪些

    linux内核和linux系统的区别:1、linux操作系统是包含linux内核的,是将linux内核进行扩展,而linux内核只提供了硬件抽象层、硬盘以及文件系统控制的核心程序;2、linux系统会在内核的基础上加入了用户界面和各种软件的支持,而linux内核则没有用户界面和软件的支持。

    2022年6月29日
    1.1K00
  • coreldraw如何填充颜色

    coreldraw填充颜色的方法 1、打开软件选择左侧的矩形工具,在工作区域里画出一个矩形。 2、工具栏里面找到填充工具,选择均匀填充。 3、在均匀填充调色框中选择需要填充的颜色,然后点击“确定”。 4、这样就填充完成了。 关于“coreldraw如何填充颜色”的内容就介绍到这里了,感谢大家的阅读。…

    2022年9月26日
    74000
  • windows打印机出现0x000006b9如何解决

    解决方法: 方法一: 1、首先我们按下键盘“win+r”,然后输入“services.msc”回车确定打开服务列表。 2、然后在其中找到“windows firewall”服务,右键选中点击“启动” 3、开启之后,我们进入“控制面板” 4、接着在其中找到并进入“查看设备和打印机” 5、然后在其中找到…

    2022年9月15日
    64300
  • MySQL数据库子查询语法规则是什么

    子查询是在查询语句里面再嵌套一个查询,这是因为我们在提取数据的时候有很多不知道的数据产生了依赖关系。此时我们就需要先查询一组数据的结果集,然后将这个结果集作用为下一个查询的对象。在 “表连接的章节”,我们曾说过子查询的效率低下的问题,其实并不是所有的子查询效率都是低下的,“WHERE” 子查询在匹配…

    2022年9月2日
    74800
  • 电脑黑白打印机能不能扫描出彩色

    黑白打印机能扫描出彩色的吗 答:黑白打印机能扫描出彩色的。 1、如果你的黑白打印机带有扫描功能,那就可以扫描彩色。 2、因为扫描和打印是分开的,不能打印彩色与扫描彩色没有关系。 3、如果我们想要扫描彩色内容的话,可以先连接打印机,打开它。 4、打开后,在“打印与扫描”下选择“扫描文档或照片” 5、然…

    2022年9月24日
    1.1K00
  • word页码怎么设置

    word页码设置教程: 1、打开需要设置的文档。 2、在工具栏中找到插入的功能。 2、插入功能中有页码功能,点击即可。 3、选择页码的出现位置。 4、选择页面的样式。 5、效果如图。 感谢各位的阅读,以上就是“word页码怎么设置”的内容了,经过本文的学习后,相信大家对word页码怎么设置这一问题有…

    2022年9月19日
    42900
注册PingCode 在线客服
站长微信
站长微信
电话联系

400-800-1024

工作日9:30-21:00在线

分享本页
返回顶部