广告
返回顶部
首页 > 资讯 > 数据库 >mysql 存储过程 查询结果集循环处理游标使用
  • 688
分享到

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

mysql存储过程查询结果集循环处理游标使用 2017-08-10 01:08:47 688人浏览 无得
摘要

注意每个版本的mysq的存储过程,触发器写法都会有些许区别,注意查看官方版本,不然你网上copy的语句可能执行无效,或者不成功 官方英文说明文档 https://dev.Mysql.com/doc/refman/5.7/en/curso

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;

 

您可能感兴趣的文档:

--结束END--

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

本文链接: https://www.lsjlt.com/news/6516.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作