Mysql存储过程循环内嵌套使用游标示例代码
作者:whsnow 时间:2024-01-27 10:18:25
BEGIN
-- 声明变量
DECLARE v_addtime_begin varchar(13);
DECLARE v_addtime_end varchar(13);
DECLARE v_borrow_id int;
DECLARE v_count int;
DECLARE s1 int;
/** 声明游标,并将查询结果存到游标中 **/
DECLARE c_borrow CURSOR FOR
SELECT ID from rocky_borrow WHERE BORROWTYPE = 2 AND PUBLISH_TIME >= UNIX_TIMESTAMP('2014-05-27') AND PUBLISH_TIME <= UNIX_TIMESTAMP('2014-07-30') ORDER by ID ASC;
/** 获取查询数量 **/
SELECT count(ID) INTO v_count from rocky_borrow WHERE BORROWTYPE = 2 AND PUBLISH_TIME >= UNIX_TIMESTAMP('2014-05-27') AND PUBLISH_TIME <= UNIX_TIMESTAMP('2014-07-30') ORDER by ID ASC;
SET s1 = 1;
-- 开始事务
START TRANSACTION;
-- 打开游标
OPEN c_borrow;
-- 循环游标
WHILE s1 < v_count+1 DO
-- 遍历游标
FETCH c_borrow INTO v_borrow_id;
SELECT t1.addtime INTO v_addtime_begin FROM (SELECT * FROM rocky_b_tenderrecord bt WHERE BORROW_ID = v_borrow_id AND tender_type = 1 ORDER BY ID ASC) t1 GROUP BY t1.borrow_id;
SELECT t1.addtime INTO v_addtime_end FROM (SELECT * FROM rocky_b_tenderrecord bt WHERE BORROW_ID = v_borrow_id AND tender_type = 1 ORDER BY ID DESC) t1 GROUP BY t1.borrow_id;
IF (v_addtime_begin IS NOT NULL) && (v_addtime_end IS NOT NULL) THEN
-- 嵌套使用游标
BEGIN
DECLARE v_id int;
DECLARE v_user_id int;
DECLARE v_type varchar(20);
DECLARE v_total decimal(20,8) DEFAULT 0;
DECLARE v_money decimal(20,8) DEFAULT 0;
DECLARE v_use_money decimal(20,8) DEFAULT 0;
DECLARE v_no_use_money decimal(20,8) DEFAULT 0;
DECLARE v_collection decimal(20,8) DEFAULT 0;
DECLARE v_to_user int(11);
DECLARE v_remark VARCHAR(1000);
DECLARE v_addtime varchar(13);
DECLARE v_addip varchar(64);
DECLARE v_first_borrow_use_money decimal(20,8) DEFAULT 0;
DECLARE done VARCHAR(45) DEFAULT '';
DECLARE t_error int DEFAULT 0;
DECLARE c_accountlog CURSOR FOR
SELECT ID,USER_ID,TYPE,TOTAL,MONEY,USE_MONEY,NO_USE_MONEY,COLLECTION,TO_USER,REMARK,ADDTIME,ADDIP,FIRST_BORROW_USE_MONEY FROM (
SELECT ID,USER_ID,TYPE,TOTAL,MONEY,USE_MONEY,NO_USE_MONEY,COLLECTION,TO_USER,REMARK,ADDTIME,ADDIP,FIRST_BORROW_USE_MONEY FROM rocky_accountlog
WHERE ADDTIME >= v_addtime_begin AND ADDTIME <= v_addtime_end AND (type = 'tender_cold' or type= 'repayment_deduct')
) t GROUP BY t.user_id HAVING count(t.user_id) > 1;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = NULL;
OPEN c_accountlog;
FETCH c_accountlog INTO v_id,v_user_id,v_type,v_total,v_money,v_use_money,v_no_use_money,v_collection,v_to_user,v_remark,v_addtime,v_addip,v_first_borrow_use_money;
WHILE (done IS NOT NULL) DO
INSERT INTO rocky_accountlog_test2 (ACCOUNTLOG_ID,USER_ID,TYPE,TOTAL,MONEY,USE_MONEY,NO_USE_MONEY,COLLECTION,TO_USER,REMARK,ADDTIME,ADDIP,FIRST_BORROW_USE_MONEY,BORROW_ID)
VALUES (v_id,v_user_id,v_type,v_total,v_money,v_use_money,v_no_use_money,v_collection,v_to_user,v_remark,v_addtime,v_addip,v_first_borrow_use_money,v_borrow_id);
FETCH c_accountlog INTO v_id,v_user_id,v_type,v_total,v_money,v_use_money,v_no_use_money,v_collection,v_to_user,v_remark,v_addtime,v_addip,v_first_borrow_use_money;
END WHILE;
CLOSE c_accountlog;
END;
END IF;
SET s1 = s1 + 1;
END WHILE;
CLOSE c_borrow;
COMMIT; -- 事务提交
END
标签:存储过程,游标
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
JavaScript实现鼠标经过显示下拉框
2024-04-28 09:52:36
![](https://img.aspxhome.com/file/2023/4/132724_0s.jpg)
浅谈python中scipy.misc.logsumexp函数的运用场景
2023-11-10 17:10:56
MYSQL安装时解决要输入current root password的解决方法
2024-01-15 07:04:26
golang API开发过程的中的自动重启方式(基于gin框架)
2024-02-03 02:56:48
在cmd中运行.py文件: python的操作步骤
2021-10-01 08:40:47
SQL左连接和右连接原理及实例解析
2024-01-21 20:35:39
一文带你看懂Vue Hook和React Hook
2024-04-22 13:24:02
在Python中进行自动化单元测试的教程
2023-07-16 04:12:30
![](https://img.aspxhome.com/file/2023/1/97711_0s.png)
Python中的单继承与多继承实例分析
2022-07-03 13:48:06
一文详解如何用GPU来运行Python代码
2022-02-26 17:49:30
![](https://img.aspxhome.com/file/2023/1/99151_0s.png)
python扫描proxy并获取可用代理ip的实例
2023-07-29 16:42:50
Python实现将一个正整数分解质因数的方法分析
2021-01-09 10:39:29
mysql update case 更新字段值不固定的操作
2024-01-15 06:25:41
Go语言中 Channel 详解
2024-01-30 04:39:48
python WindowsError的错误代码详解
2021-09-03 18:58:45
MYSQL建立外键失败几种情况记录Can't create table不能创建表
2024-01-22 19:57:22
在sql中实现取一行最大值或者最小值
2024-01-24 21:34:28
![](https://img.aspxhome.com/file/2023/2/112872_0s.jpg)
Mysql动态更新数据库脚本的示例讲解
2024-01-23 11:22:49
javascript将数字转换整数金额大写的方法
2024-04-30 10:08:34
pandas:get_dummies()与pd.factorize()的用法及区别说明
2023-07-10 22:17:32
![](https://img.aspxhome.com/file/2023/0/97520_0s.png)