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

相关推荐

  • 项目团队如何高效沟通?

    在职场工作中,最常遇到的问题就是 沟通 。 如何能在最短的时间做到令对方明白您的目的? 彼此确认好双方的需求? 确保大家都明确任务最终想要达成的效果? 这需要极强的沟通和协作能力,而高效沟通几乎是现下每个团队的管理盲点。 团队沟通是团队协作的基础。 为了更好地合作,就必…

    2022年3月20日
    5600
  • 多项目管理方法有哪些

    多项目管理方法主要有:1.阶段化管理;2.量化管理;3.优化管理这三个方面。项目管理方法是关于如何进行项目管理的方法,是可在大部分项目中应用的方法。 一、阶段管理 阶段化管理指的是从立项之初直到系统运行维护的全过程。根据工程项目的特点,我们可将项目管理分为若干个小的阶段。 市场信息 1)市场信息方面…

    2022年3月25日
    10400
  • 怎么使用linux命令备份文件夹

    linux命令能备份文件夹。有两种命令用于备份文件夹:1、cp命令,该命令用于复制文件或文件夹,语法为“cp [options] source dest”;2、dump命令,该命令用于备份文件系统,语法为“dump [-cnu][-0123456789]…”。 linux命令备份文件夹 …

    2022年6月29日
    3000
  • 疫情期间,HR团队是如何实行远程办公的?

    2020年的春节是个不平常的春节,新型冠状病毒突如其来,为了控制病毒传播,国务院办公厅宣布延长2020年春节假期至2月2日,各地政府也相继出台了延期开工政策。 Worktile积极响应国家政策,保障每位员工的身体健康,决定全体员工先在家远程办公。为了战胜疫情,实现真正有效率有成果的远程办公,公司HR…

    2022年3月20日
    10700
  • 知识库软件有哪些

    这里整理了国内外最好用的10款知识库软件,适用对象从团队到个人,他们分别是:1、PingCode Wiki;2、Baklib;3、有道云笔记;4、印象笔记;5、RemNote;6、石墨文档;7、Notion;8、语雀;9、幕布;10、Obsidian。具体功能我们将在文章中介绍。 一、团队知识库软件…

    2022年3月18日
    69600
  • git如何删除某个分支

    git删除某个分支的方法:1、利用“git branch –delete dev”命令删除本地分支;2、利用“git push origin –delete branch”命令删除远程分支;3、利用“git branch –delete –remote…

    2022年6月29日
    21800
  • 用办公协作思维提升新媒体运营工作效率

    新媒体运营行业是随着互联网发展而来的职位,在每个公司都担任着推广营销的重要工作。它要求相关从业者 “懂营销” ,可以运用良好的推广营销方式,善于利用热点事件,实现有效的品牌或产品营销。除此之外,也要精于内容和策划,对数据分析也要在行。 简单来说就是:“会写文章,能P图,玩的了创意…

    2022年3月20日
    8100
  • mysql支持外键吗

    mysql支持外键。在MySQL中,外键主要用来建立主表与从表的关联关系,可以为两个表的数据建立连接,约束两个表中数据的一致性和完整性;当主表删除某条记录时,从表中与之对应的记录也必须有相应的改变。一个表可以有一个或多个外键,外键可以为空值,若不为空值,则每一个外键的值必须等于主表中主键的某个值;且…

    2022年6月29日
    1000
  • Mysql中锁的使用场景是什么

    Mysql中锁的使用场景主要有:常见锁类型、Mysql引擎介绍、常用引擎间的区别、共享锁与排他锁、排他锁的实际应用、共享锁的实际应用、死锁的发生、另一种发生死锁的情景、死锁的解决方式、意向锁和计划锁、乐观锁和悲观锁。 一、常见锁类型 表级锁,锁定整张表 页级锁,锁定一页 行级锁,锁定一行 共享锁,也…

    2022年6月29日
    1700
  • Redis+AOP怎么自定义注解实现限流

    今天分享文章“Redis+AOP怎么自定义注解实现限流”,主要从:下载、解压、准备编译、编译等几个方面为大家介绍,希望能帮到您。 下载 1,下载页面 2,下载 解压 tar -xzvf redis-5.0.7.tar.gz 准备编译 1, 请在操作前确认gcc是否已安装,gcc -v 如未安装,可以…

    2022年6月29日
    1000
联系我们
关注微信
关注微信
分享本页
返回顶部