1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > 详细讲解mysql的存储过程 游标 事务

详细讲解mysql的存储过程 游标 事务

时间:2023-01-02 16:03:48

相关推荐

详细讲解mysql的存储过程 游标  事务

数据库|mysql教程

mysql,过程,存储

数据库-mysql教程

本文主要介绍了mysql的存储过程、游标 、事务实例详解的相关资料,这里举实例说明MySQL 存储过程与游标和事务,需要的朋友可以参考下,希望能帮助到大家。

博客 源码,ubuntu内网通外网,tomcat 只有2g,爬虫动物检疫,apache php导出慢,广东第三方seo优化有哪些lzw

相关mysql视频教学推荐:《mysql教学》

易支付第三方接口源码,ubuntu环境发邮件,爬虫追女朋友,云之梦 php,seo帝国seodglzw

mysql的存储过程、游标 、事务实例详解

淘宝客鹊桥分享源码,vscode失焦自动格式化,怎么ftp ubuntu,tomcat 服务器维护,爬虫框架组成,php优秀框架,安徽seo优化需要多少钱lzw

下面是自己曾经编写过的mysql数据库存储过程,留作存档,以后用到的时候拿来参考。

其中,涉及到了存储过程、游标(双层循环)、事务。

【说明】:代码中的注释只针对当时业务而言,无须理会。

代码如下:

DELIMITER $$DROP PROCEDURE IF EXISTS `transferEmailTempData`$$CREATE PROCEDURE transferEmailTempData(IN jobId VARCHAR(24))BEGIN DECLARE idval VARCHAR(24) DEFAULT \; DECLARE taskIdval VARCHAR(24) DEFAULT \; DECLARE groupIdval VARCHAR(24) DEFAULT \; DECLARE emailval VARCHAR(50) DEFAULT \; /*标识正式表是否存在一条相同数据,即:groupId、email相同*/ DECLARE infoId VARCHAR(24) DEFAULT \; /*标识事务错误*/ DECLARE err INT DEFAULT 0; /*达到一定数量就进行提交,计数器*/ DECLARE counts INT DEFAULT 0; /*标识是否回滚过*/ DECLARE isrollback INT DEFAULT 0; /*游标遍历时,作为判断是否遍历完全部记录的标记*/ DECLARE done INTEGER DEFAULT 0; /*获取临时表该任务的数据*/ DECLARE cur CURSOR FOR SELECT id,taskId,groupId,email FROM `t_email_data_temp` WHERE taskId=jobId; /*根据群组id、email查询是否存在相同记录*/ DECLARE cur2 CURSOR FOR SELECT id FROM `t_email_info` e WHERE e.`group_id` = groupIdval AND e.`email_address` = emailval;/* 出现错误,设置为1,只要发生异常就回滚*/ DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET err=1; /*声明当游标遍历完全部记录后将标志变量置成某个值*/ DECLARE CONTINUE HANDLER FOR NOT FOUND SET done=1; /*开启事务*/ START TRANSACTION; /*打开游标*/ OPEN cur; /*使用LOOP循环遍历*/ out_loop:LOOP/*将每一条结果对应的字段值赋值给变量*/ FETCH cur INTO idval,taskIdval,groupIdval,emailval; IF done = 1 THENLEAVE out_loop; END IF; /*打开第二个游标*/ OPEN cur2;SET done = 0;FETCH cur2 INTO infoId; /*如果正式表不存在相同groupId and email记录,添加到正式表*/IF done = 1 THEN /*插入正式表*/ INSERT INTO `t_email_info` VALUES(idval,emailval,groupIdval,0,\,NOW(),admin,NOW(),admin);/*删除临时数据*/ DELETE FROM `t_email_data_temp` WHERE id = idval;/*计数器,每1000条才提交*/ SET counts = counts + 1;/*发生异常,回滚*/ IF err=1 THENSET isrollback=1;ROLLBACK; ELSEIF counts = 1000 THEN COMMIT; /*达到1000条提交后,重置计数器*/ SET counts=0;END IF; END IF;ELSE /*已经存在相同记录,则删除该记录*/ IF done=0 THENDELETE FROM `t_email_data_temp` WHERE id = idval; END IF;END IF;FETCH cur2 INTO infoId; CLOSE cur2; /*控制外部的循环,该步骤不能缺少,否则只循环一次就结束了*/ SET done=0;END LOOP out_loop; CLOSE cur; /*如果没有发生过回滚事件,则更新task状态*/ /*如果回滚过,不更新task状态,下次执行任务的时候,会再次将剩余没有提交的数据进行添加到正式表*/ IF isrollback=0 THEN UPDATE `t_email_task` t SET t.`if_finish` = 1 WHERE t.`id`=jobId; END IF; END$$DELIMITER ;

MySQL存储过程和事务的简单介绍

存储过程的定义、修改和删除的操作方法

MySQL存储过程 游标 错误处理的示例代码

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。