我的编程空间,编程开发者的网络收藏夹
学习永远不晚

mysql 存储过程 查询结果集循环处理游标使用

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

mysql 存储过程 查询结果集循环处理游标使用

mysql 存储过程 查询结果集循环处理游标使用

注意每个版本的mysq的存储过程,触发器写法都会有些许区别,注意查看官方版本,不然你网上copy的语句可能执行无效,或者不成功

官方英文说明文档

https://dev.mysql.com/doc/refman/5.7/en/cursors.html

demo 数据版本mysql 5.7.22-log 

 

如果需要debug你写的存储过程推荐:

dbForge Studio for MySQL 这个工具挺好使的

使用请参考

https://blog.csdn.net/weixin_42740530/article/details/94553996
 

CREATE DEFINER = "zx"@"%"
PROCEDURE `v2-20200212`.zx11 ()
BEGIN
  -- 声明一些需要用到的变量
  DECLARE done int DEFAULT FALSE;
  DECLARE z_id int DEFAULT 0;
  DECLARE z_admin_login_name varchar(255);
  DECLARE z_remark varchar(255);
  -- 声明游标
  DECLARE admin_list CURSOR FOR
  SELECT
    `id`,
    `admin_login_name`,
    `remark`
  FROM admin;
  -- 声明 是否没有记录
  DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;
 
  -- 打开游标
  OPEN admin_list;
-- 开始循环
read_loop:
  LOOP
    -- 注意声明变量类型和接受数据的顺序一致
    FETCH admin_list INTO z_id, z_admin_login_name, z_remark;
 
    -- 如果没有结果集就退出循环
    IF done THEN
      LEAVE read_loop;
    END IF;
    -- 具体执行的sql语句
    UPDATE admin
    SET remark = z_id
    WHERE id = z_id;
  -- 结束循环
  END LOOP;
 
  -- 关闭游标
  CLOSE admin_list;
END

官方demo

CREATE PROCEDURE curdemo()
BEGIN
  DECLARE done INT DEFAULT FALSE;
  DECLARE a CHAR(16);
  DECLARE b, c INT;
  DECLARE cur1 CURSOR FOR SELECT id,data FROM test.t1;
  DECLARE cur2 CURSOR FOR SELECT i FROM test.t2;
  DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;
 
  OPEN cur1;
  OPEN cur2;
 
  read_loop: LOOP
    FETCH cur1 INTO a, b;
    FETCH cur2 INTO c;
    IF done THEN
      LEAVE read_loop;
    END IF;
    IF b < c THEN
      INSERT INTO test.t3 VALUES (a,b);
    ELSE
      INSERT INTO test.t3 VALUES (a,c);
    END IF;
  END LOOP;
 
  CLOSE cur1;
  CLOSE cur2;
END;

 

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

mysql 存储过程 查询结果集循环处理游标使用

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

mysql 存储过程 查询结果集循环处理游标使用

注意每个版本的mysq的存储过程,触发器写法都会有些许区别,注意查看官方版本,不然你网上copy的语句可能执行无效,或者不成功 官方英文说明文档 https://dev.mysql.com/doc/refman/5.7/en/cursors.html demo
mysql 存储过程 查询结果集循环处理游标使用
2017-08-10

mysql存储过程查询结果循环遍历 判断 赋值 游标等基本操作

一、首先说下本篇博客所实现功能的背景和功能是怎样的:       背景:因为公司项目开始迁移新平台项目,所以以前的平台老数据以及订单信息需要拆分表,而且需要业务逻辑来分析以前的订单表,来拆分成另外的几个新表, 包括增加新的流水分析,以及更新其他用户或者商家的余
mysql存储过程查询结果循环遍历 判断 赋值 游标等基本操作
2017-11-25

Mysql 存储过程中使用游标循环读取临时表

游标游标(Cursor)是用于查看或者处理结果集中的数据的一种方法。游标提供了在结果集中一次一行或者多行前进或向后浏览数据的能力。 游标的使用方式定义游标:Declare 游标名称 CURSOR for table;(table也可以是se
2022-06-01

我们如何在 MySQL 存储过程中处理结果集?

我们可以使用游标来处理存储过程中的结果集。基本上,游标允许我们迭代查询返回的一组行并相应地处理每一行。为了演示 CURSOR 在 MySQL 存储过程中的使用,我们正在创建以下存储过程,该过程基于名为“student_info”的表的值,如
2023-10-22

Mybatis集成MySQL使用游标查询处理大批量数据方式

MyBatis集成MySQL游标查询,通过将结果集保留在数据库中,减少网络开销,延迟结果集处理和处理大数据集。优点包括减少网络消耗、分批处理和轻量化资源消耗。缺点包括潜在锁定、资源占用和复杂性。使用步骤涉及建立、打开、获取和关闭游标。MyBatis集成需要创建游标、配置连接和使用SqlSession创建游标。示例代码演示了如何使用游标查询。注意事项强调及时关闭游标、性能优化和使用批处理模式。
Mybatis集成MySQL使用游标查询处理大批量数据方式
2024-04-02

编程热搜

目录