MySQL双层游标嵌套循环实现方法

 更新时间:2024年05月05日 11:06:50   作者:bacawa  
要实现逐行获取数据,需要用到MySQL中的游标,一个游标相当于一个for循环,这里需要用到2个游标,如何在MySQL中实现游标双层循环呢,下面小编给大家分享MySQL双层游标嵌套循环方法,感兴趣的朋友跟随小编一起看看吧

1、需求描述

1、在项目中,需要将A表中主键id,逐个取出,作为条件,在B表中去逐一查询,将B表查询到的结果集(A表B表关系:一对多),逐一遍历,连同A表的id拼接运算,逐个插入到C表中。

2、 在Java中很容易实现,A表获取到的结果集,循环遍历取出id,去B表查询;遍历B表结果集,插入到C表中。 相当于2个循环,即可实现需求。 这样会有一个问题,频繁连接数据库,造成大量资源开销。 那么在存储过程中,该怎么实现呢?

2、思路

  要实现逐行获取数据,需要用到MySQL中的游标,一个游标相当于一个for循环,这里需要用到2个游标。如何在MySQL中实现游标双层循环呢?

3、创建存储过程

CREATE DEFINER=`root`@`%` PROCEDURE `student`()
BEGIN
	-- 定义变量
		-- 假设有一张学生表,有id,student_name字段
		DECLARE outer_done INT DEFAULT FALSE; -- 外层游标控制变量
		DECLARE studentTableId int;    -- 学生表ID
		declare studentTableName VARCHAR(100);   -- 学生姓名
		declare outer_cursor cursor for select id,student_name from student_table  where `disable` = '0'; 
		DECLARE CONTINUE HANDLER FOR NOT FOUND SET outer_done = TRUE;
		open outer_cursor;     
			while not outer_done do
					fetch outer_cursor into studentTableId,studentTableName;  -- 这里循环取值,赋值到上面定义的变量中
						-- 开始定义内层游标
						BEGIN -- inner BEGIN
								-- 假设有一张成绩表,包含字段id,student_name,score字段
								DECLARE scoreTableId int;    -- 成绩Id
								declare scoreTableName VARCHAR(100);    -- 学生名字
								declare scoreTableScore float;   -- 学生分数
								DECLARE inner_done int DEFAULT FALSE ;
								DECLARE my_value VARCHAR(255);
								declare inner_cursor cursor for select id,student_name,score from score_table where `disable` = '0'; 
								DECLARE CONTINUE HANDLER FOR NOT FOUND SET inner_done  = TRUE ;
								OPEN inner_cursor; -- 打开内层游标
								WHILE not inner_done DO -- inner WHILE
									FETCH inner_cursor INTO scoreTableId,scoreTableName,scoreTableScore ; -- 从【内层游标】中获取数据,赋值到定义变量中
									 IF studentTableName = scoreTableName THEN    -- 判断名字一样(测试,生产不要用名称进行判断)
										set my_value = CONCAT_WS('-',studentTableName,scoreTableScore);    -- 给变量赋值 CONCAT_WS函数可以按照固定的连接符,将数据进行连接,例如 张三-95
										select my_value;     -- 打印变量值
									 END IF;
									 -- 假设有一张汇总表(summary_table),将处理的数据进行更新
									 update summary_table set summary_column=my_value where summary_table_student_id=studentTableId;
								END WHILE ; -- END inner WHILE
								CLOSE inner_cursor; -- 循环结束后,关闭内层游标
						END; -- END inner BEGIN
			end while;        
		close outer_cursor;  
END

看图清晰一点。

到这里就完成了,存储过程里面的注释很详细,就不多赘述了,我在写存储过程中也是踩了不少坑,记录下来,希望能帮到各位coder。

到此这篇关于MySQL双层游标嵌套循环方法的文章就介绍到这了,更多相关mysql游标嵌套循环内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL5.7.03 更换高版本到MySQL 5.7.17安装过程及发现问题解决方案

    MySQL5.7.03 更换高版本到MySQL 5.7.17安装过程及发现问题解决方案

    这篇文章主要介绍了MySQL5.7.03 更换高版本到MySQL 5.7.17安装过程及发现问题解决方案,需要的朋友可以参考下
    2017-08-08
  • MySQL表分区配置入门指南

    MySQL表分区配置入门指南

    这篇文章主要为大家介绍了MySQL表分区配置入门指南,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-05-05
  • MySQL分布式事务xa的介绍与使用小结

    MySQL分布式事务xa的介绍与使用小结

    xa指的是分布式事务,传统的事务针对的是单机MySQL,本文主要介绍了MySQL分布式事务xa的介绍与使用小结,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助
    2024-07-07
  • 为什么MySQL数据库索引选择使用B+树?

    为什么MySQL数据库索引选择使用B+树?

    今天小编就为大家分享一篇关于为什么MySQL数据库索引选择使用B+树?,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-03-03
  • mysql5.7同时使用group by和order by报错问题

    mysql5.7同时使用group by和order by报错问题

    这篇文章主要介绍了mysql5.7同时使用group by和order by报错的问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-08-08
  • 两个MySql服务的应用

    两个MySql服务的应用

    两个MySql服务的应用兼容方法。
    2009-10-10
  • 解决MySQL:Invalid GIS data provided to function st_geometryfromtext问题

    解决MySQL:Invalid GIS data provided to&nbs

    这篇文章主要介绍了解决MySQL:Invalid GIS data provided to function st_geometryfromtext问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-06-06
  • MySQL创建横向直方图的解决方案

    MySQL创建横向直方图的解决方案

    这篇文章主要给大家介绍了关于MySQL创建横向直方图的解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-02-02
  • MySQL学习笔记3:表的基本操作介绍

    MySQL学习笔记3:表的基本操作介绍

    要操作表首先需要选定数据库,因为表是存在于数据库内的;表的基本操作包括:创建表、显示表、查看表基本结构、查看表详细结构以及删除表等等,需要了解的朋友可以参考下
    2013-01-01
  • MySQL深入浅出掌握触发器用法

    MySQL深入浅出掌握触发器用法

    触发器是SQLserver提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,事件是在 MySQL 5.1后引入的,有点类似操作系统的计划任务,但是周期性任务是内置在MySQL服务端执行的
    2022-05-05

最新评论