我是靠谱客的博主 畅快母鸡,最近开发中收集的这篇文章主要介绍mysql循环遍历获取_mysql存储过程之循环遍历查询结果集,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

-- 创建存储过程之前需判断该存储过程是否已存在,若存在则删除

DROP PROCEDURE IF EXISTS init_reportUrl;

-- 创建存储过程

CREATE PROCEDURE init_reportUrl()

BEGIN

-- 定义变量

DECLARE s int DEFAULT 0;

DECLARE report_id varchar(255);

DECLARE report_url varchar(256);

-- 定义游标,并将sql结果集赋值到游标中

DECLARE report CURSOR FOR select reportId,reportUrl from patrolReportHistory;

-- 声明当游标遍历完后将标志变量置成某个值

DECLARE CONTINUE HANDLER FOR NOT FOUND SET s=1;

-- 打开游标

open report;

-- 将游标中的值赋值给变量,注意:变量名不要和返回的列名同名,变量顺序要和sql结果列的顺序一致

fetch report into report_id,report_url;

-- 当s不等于1,也就是未遍历完时,会一直循环

while s<>1 do

-- 执行业务逻辑

update patrolreporthistory set reportUrl = CONCAT(‘patrolReport.html?monitorId=‘,substring(report_url,15,1),‘&reportId=‘,report_id) where reportId=report_id;

-- 将游标中的值再赋值给变量,供下次循环使用

fetch report into report_id,report_url;

-- 当s等于1时表明遍历以完成,退出循环

end while;

-- 关闭游标

close report;

END;

-- 执行存储过程

call init_reportUrl()

---------------------

最后

以上就是畅快母鸡为你收集整理的mysql循环遍历获取_mysql存储过程之循环遍历查询结果集的全部内容,希望文章能够帮你解决mysql循环遍历获取_mysql存储过程之循环遍历查询结果集所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(50)

评论列表共有 0 条评论

立即
投稿
返回
顶部