mysql 存储过程 查询结果集循环处理游标使用「建议收藏」

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

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

代码100分

官方demo

代码100分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;

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/8050.html

(0)
上一篇 2023-03-08
下一篇 2023-03-08

相关推荐

  • 中台架构与实现:基于DDD和微服务_tidb架构

    中台架构与实现:基于DDD和微服务_tidb架构数据库作为信息系统的核心,数据库设计需要根据用户的需求,针对业务逻辑上,设计结构和建立数据库。由于数据库应用系统的复杂性,数据库的设计不可能一蹴而就,也没有统一的最好的设计结构,因为对于不同的业务来…

    2023-04-11
    150
  • Python中的析构函数详解

    Python中的析构函数详解在Python中,当我们创建一个对象时,系统会给该对象分配一块内存,该内存会在对象被删除时被释放。而当我们需要在对象被删除时执行一些必要的清理操作,这个时候,Python中的析构函数就派上用场了。本文将介绍Python中的析构函数,包括如何实现和使用。

    2024-06-27
    46
  • mysql的buffer pool 和 change buffer「建议收藏」

    mysql的buffer pool 和 change buffer「建议收藏」线上三张图吧: 一、innodb系统架构图 …

    2023-04-04
    165
  • 北斗对时设备(GPS校时产品)在数字城市系统中的应用「终于解决」

    北斗对时设备(GPS校时产品)在数字城市系统中的应用「终于解决」北斗对时设备(GPS校时产品)在数字城市系统中的应用

    2023-03-03
    145
  • redis安装与使用_etc在哪里安装

    redis安装与使用_etc在哪里安装NoSQL 1. 定义 NoSQL(Not Only SQL)即不仅仅是 SQL,泛指非关系型的数据库 2. 为什么使用 NoSQL? 传统关系数据库在应付动态网站、特别是超大规模和高并发的纯动态网站

    2023-05-30
    163
  • Python变量:数据存储的核心元素

    Python变量:数据存储的核心元素Python是一门高级编程语言,它在业界和学术界都有广泛的应用。Python是一门解释型语言,因此,变量在Python中具有很高的灵活性。Python中的变量是数据存储的核心元素,它允许程序员在运行时动态地分配和释放内存。本文将介绍Python中的变量及其在程序中的应用。

    2023-12-28
    114
  • Python判断是否为空

    Python判断是否为空在编写Python程序时,我们常常需要对数据进行空值判断,以便在后续代码中避免出现错误或异常。本文将从多个方面详细介绍Python中的判断是否为空的方法,帮助读者更好地理解和运用这一常用操作。

    2024-04-25
    63
  • 学习使用PyCharm Debug调试Python程序

    学习使用PyCharm Debug调试Python程序本文将介绍如何在PyCharm中使用调试器Debug调试Python程序。调试器是用于查找和解决软件中的错误的重要工具,它可以帮助程序员更快地找出问题所在且更快地解决问题。在PyCharm中使用调试器Debug可以一步一步地执行程序并查看正在执行的每个代码行,同时还可以检查变量的值和状态。

    2024-07-12
    43

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注