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。

  有问题欢迎评论区留言或者私信,我看到就会回复。

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
智慧校园整体解决方案是响应国家教育信息化政策,结合教育改革和技术创新的产物。该方案以物联网、大数据、人工智能和移动互联技术为基础,旨在打造一个安全、高效、互动且环保的教育环境。方案强调从数字化校园向智慧校园的转变,通过自动数据采集、智能分析和按需服务,实现校园业务的智能化管理。 方案的总体设计原则包括应用至上、分层设计和互联互通,确保系统能够满足不同用户角色的需求,并实现数据和资源的整合与共享。框架设计涵盖了校园安全、管理、教学、环境等多个方面,构建了一个全面的校园应用生态系统。这包括智慧安全系统、校园身份识别、智能排课及选课系统、智慧学习系统、精品录播教室方案等,以支持个性化学习和教学评估。 建设内容突出了智慧安全和智慧管理的重要性。智慧安全管理通过分布式录播系统和紧急预案一键启动功能,增强校园安全预警和事件响应能力。智慧管理系统则利用物联网技术,实现人员和设备的智能管理,提高校园运营效率。 智慧教学部分,方案提供了智慧学习系统和精品录播教室方案,支持专业级学习硬件和智能化网络管理,促进个性化学习和教学资源的高效利用。同时,教学质量评估中心和资源应用平台的建设,旨在提升教学评估的科学性和教育资源的共享性。 智慧环境建设则侧重于基于物联网的设备管理,通过智慧教室管理系统实现教室环境的智能控制和能效管理,打造绿色、节能的校园环境。电子班牌和校园信息发布系统的建设,将作为智慧校园的核心和入口,提供教务、一卡通、图书馆等系统的集成信息。 总体而言,智慧校园整体解决方案通过集成先进技术,不仅提升了校园的信息化水平,而且优化了教学和管理流程,为学生、教师和家长提供了更加便捷、个性化的教育体验。
### 回答1: MySQL 中的游标可以嵌套循环使用,实现比较复杂的数据处理逻辑。下面是一个简单的示例: ``` DECLARE cur1 CURSOR FOR SELECT id FROM table1; DECLARE cur2 CURSOR FOR SELECT value FROM table2 WHERE table1_id = @id; OPEN cur1; FETCH cur1 INTO @id; WHILE @@FETCH_STATUS = 0 DO OPEN cur2; FETCH cur2 INTO @value; WHILE @@FETCH_STATUS = 0 DO -- do something with @id and @value FETCH cur2 INTO @value; END WHILE; CLOSE cur2; FETCH cur1 INTO @id; END WHILE; CLOSE cur1; ``` 上面的代码中,先声明了两个游标 `cur1` 和 `cur2`,分别用于遍历表 `table1` 和表 `table2`。在第一个游标中,使用 `FETCH` 语句获取 `id`,并将其赋值给变量 `@id`。然后在 `WHILE` 循环中,检查 `@@FETCH_STATUS` 是否为 0,即是否还有数据可以获取。如果有,进入第二个游标循环,使用 `@id` 来过滤 `table2` 中的数据,并使用 `FETCH` 语句获取 `value`,并将其赋值给变量 `@value`。在第二个游标循环中,同样检查 `@@FETCH_STATUS` 是否为 0,如果有,就可以对 `@id` 和 `@value` 进行处理。最后,关闭 `cur2` 游标,继续在第一个游标中获取下一个 `id`,直到所有数据都处理完毕。 需要注意的是,在使用游标嵌套循环时,要尽量避免使用过多的嵌套,以避免性能问题。同时,也要注意游标的使用方式,确保在使用完毕后及时关闭游标,以释放资源。 ### 回答2: MySQL中的游标是一种用于遍历查询结果集的机制。游标嵌套循环是指在一个循环嵌套另一个循环,并使用游标来控制内部循环的遍历过程。 在MySQL中,可以通过以下步骤来实现游标嵌套循环: 1. 声明外部循环游标:首先,需要声明一个外部循环游标,用于遍历外部查询的结果集。 2. 打开外部循环游标:在开始外部循环之前,需要使用OPEN语句打开外部游标,准备开始遍历外部结果集。 3. 声明内部循环游标:在外部循环内部,需要声明一个内部循环游标,用于遍历内部查询的结果集。 4. 打开内部循环游标:在开始内部循环之前,需要使用OPEN语句打开内部游标,准备开始遍历内部结果集。 5. 循环遍历内部结果集:在内部循环中使用FETCH语句来从内部游标中获取一行结果,并进行相应的处理。 6. 关闭内部循环游标:在内部循环结束后,使用CLOSE语句来关闭内部游标,释放资源。 7. 关闭外部循环游标:在外部循环结束后,使用CLOSE语句来关闭外部游标,释放资源。 通过以上步骤,可以实现游标嵌套循环的功能。在嵌套循环中,外部循环的每一次迭代都会执行内部循环的全部迭代,直到外部循环结束。这种方法可以用于处理需要对多个结果集进行复杂操作的情况,提供了一种灵活的查询和处理方式。 需要注意的是,游标嵌套循环可能会导致性能问题,特别是在处理大数据量时。因此,在使用游标嵌套循环时,应谨慎使用,并根据实际情况考虑其他更高效的处理方式。 ### 回答3: MySQL中的游标嵌套循环是指在一个游标内部嵌套了另一个游标,并通过循环来处理嵌套游标游标是一种数据库对象,用于从查询结果中逐行获取数据。在MySQL中,使用游标需要以下步骤: 1. 声明并定义游标:通过DECLARE语句来声明和定义游标,可以指定游标的名称、查询语句和其他属性。 2. 打开游标:使用OPEN语句来打开游标,使其准备好获取数据。 3. 循环获取数据:使用FETCH语句来逐行获取游标所指向的查询结果数据。可以通过循环的方式获取所有数据或者仅获取所需的数据。 4. 关闭游标:使用CLOSE语句来关闭游标,释放资源。 在游标嵌套循环中,内层游标的查询依赖于外层游标的结果。嵌套循环的步骤如下: 1. 声明并定义外层游标。 2. 打开外层游标。 3. 循环获取外层游标的数据。 4. 在外层循环中,声明并定义内层游标,并将内层游标的查询条件绑定到外层游标的数据。 5. 打开内层游标。 6. 循环获取内层游标的数据。 7. 关闭内层游标。 8. 关闭外层游标。 通过游标嵌套循环可以在多个数据集之间进行关联操作。对于每个外层数据,内层循环可以获取相关的数据进行处理。嵌套循环可以用于完成复杂的数据处理和逻辑操作,但是需要注意效率和性能的问题,因为每次循环都需要执行数据库操作,可能会导致性能下降。 总之,MySQL中的游标嵌套循环是一种处理复杂数据操作的方法,通过嵌套的方式将多个数据集关联起来,可以提高数据处理的灵活性和精确性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值