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
0
投稿
猜你喜欢
- 下面一段代码给大家带来了python实现12306登录功能,具体代码如下所示:#!/usr/bin/env pythonimport req
- 1、什么是归一化:归一化就是把一组数(大于1)化为以1为最大值,0为最小值,其余数据按百分比计算的方法。如:1,2,3.,那归一化后就是:0
- 对于Python内置函数sorted(),先拿来跟list(列表)中的成员函数list.sort()进行下对比。在本质上,list的排序和内
- pyhook下载:http://sourceforge.net/projects/pyhook/files/pyhook/1.5.1/pyh
- unittest是python的一个单元测试框架关于断言它是用于对一个确定结果和预测结果的一种判断,如果结果正确无任何返回效果,如果结果错误
- a. 如果欲使用gb2312编码,那么php要输出头:header(“Content-Type: text/html; charset=gb
- 一、作业需求 二、流程图三、源码与具体思路 import shutilimport osimport sysUSER_LOGIN
- MooTools 1.2的整理排序类Sortables原文地址:30 Days of Mootools 1.2 Tutorials - Da
- 如下所示:import numpy as npimport matplotlib.pyplot as pltx = np.linspace(
- 自己写的小工具,可以直接获取csdn文章并转换为markdown格式效果图核心代码from PySide2.QtWidgets import
- 编辑距离编辑距离(Edit Distance),又称Levenshtein距离,是指两个字串之间,由一个转成另一个所需的最少编辑操作次数。编
- <?php $url="http://www.golden-book.com/booksinfo/12/264.html&q
- 汉字转换为UTF-8的一段代码终于找到这段代码了,一个ASP写的中文转UTF-8,大家可以试试function chinese2u
- 问题你想改变对象实例的打印或显示输出,让它们更具可读性。解决方案要改变一个实例的字符串表示,可重新定义它的 __str__() 和 __re
- 推荐系统MostPopular算法的Python实现MostPopular 算法的 是指对每个用户都选择出当前流行度最高的Top-K个物品进
- 问题: 1.购物车中的数据是否应该存储在数据库中? 我特别想知道在真正的项目中,那些真正的软件工程师是如何考虑这个问题的。在Google上一
- 实现了宽度、高度、透明度的渐变,还能以高度宽度中点为中心,还扩展成以任意点为中心渐变(实例中以点击点为中心)。<!DOCTYPE ht
- L2正则化原理:过拟合的原理:在loss下降,进行拟合的过程中(斜线),不同的batch数据样本造成红色曲线的波动大,图中低点也就是过拟合,
- 本文实例为大家分享了python tkinter实现屏保程序的具体代码,供大家参考,具体内容如下该脚本摘录自:2014年辛星tkinter教
- 以前写的很简单,只有几句话,最近发现本文是本博客阅读量最大的一篇文章,觉得这样有种把人骗进来的感觉,于是又细化了一些。如果还有不好的地方,欢