MySql存储过程 CURSOR循环
游标
游标(Cursor)是处理数据的一种方法,为了查看或者处理结果集中的数据,游标提供了在结果集中一次一行或者多行前进或向后浏览数据的能力。
使用步骤
- 声明一个游标: declare 游标名称 CURSOR for table;(这里的table可以是你查询出来的任意集合)
- 打开定义的游标:open 游标名称;
- 获得下一行数据:FETCH 游标名称 into field_1, field_2;
- 需要执行的语句(增删改查):这里视具体情况而定
- 释放游标:CLOSE 游标名称;
注:存储过程临时字段定义需要在游标定义之前。
示例:
delimiter ;; drop procedure if exists `proc_test` ;; CREATE PROCEDURE `proc_test`() BEGIN -- 定义变量 DECLARE done INT DEFAULT FALSE;
DECLARE field_1 VARCHAR(20); DECLARE field_2 VARCHAR(20);-- 创建游标,并存储数据 DECLARE cur_list CURSOR FOR SELECT id, name FROM user; -- 游标中的内容执行完后将done设置为true DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = true; -- 打开游标 OPEN cur_list; -- 执行循环 read_loop : LOOP -- 取游标中的值 FETCH cur_list INTO field_1, field_2; -- 判断是否结束循环,一定要放到FETCH之后,因为在fetch不到的时候才会设置done为true -- 如果放到fetch之前,先判断done,这个时候done的值还是之前的循环的值,因此就会导致循环一次 IF done THEN LEAVE read_loop; END IF;
-- 执行SQL操作 SET @sql_insert = CONCAT("insert into user_bak(id, name) VALUES ('", field_1, "','", field_2 ,"')"); PREPARE sqlli FROM @sql_insert; EXECUTE sqlli; COMMIT; END LOOP read_loop; -- 释放游标 CLOSE cur_list; END ;; delimiter;
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)