MySql存储过程 CURSOR循环

游标

  游标(Cursor)是处理数据的一种方法,为了查看或者处理结果集中的数据,游标提供了在结果集中一次一行或者多行前进或向后浏览数据的能力。

使用步骤

  1. 声明一个游标: declare 游标名称 CURSOR for table;(这里的table可以是你查询出来的任意集合)
  2. 打开定义的游标:open 游标名称;
  3. 获得下一行数据:FETCH  游标名称 into field_1, field_2;
  4. 需要执行的语句(增删改查):这里视具体情况而定
  5. 释放游标: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;
复制代码

 

 

 

posted @   fieldtianye  阅读(9347)  评论(1编辑  收藏  举报
编辑推荐:
· 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)
点击右上角即可分享
微信分享提示