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
投稿

猜你喜欢

  • JavaScript实现鼠标经过显示下拉框

    2024-04-28 09:52:36
  • 浅谈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
  • Python中的单继承与多继承实例分析

    2022-07-03 13:48:06
  • 一文详解如何用GPU来运行Python代码

    2022-02-26 17:49:30
  • 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
  • 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
  • asp之家 网络编程 m.aspxhome.com