您的位置:首页 > 数据库 > MySQL

MYSQL游标使用

2015-07-28 14:46 597 查看
CREATE PROCEDURE `sp_UpdateData`()
BEGIN
DECLARE v_card_id VARCHAR(50);
/*修改会员卡的几个金额*/
DECLARE done INT DEFAULT FALSE;
DECLARE cur CURSOR FOR
SELECT main.card_id FROM mem_card main
INNER JOIN mem_card_extend b ON main.card_id=b.card_id
WHERE main.status_code=1 AND b.status_code=1
AND main.sale_status=2
GROUP BY main.card_id;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;
OPEN cur;
read_loop: LOOP
FETCH cur INTO v_card_id;
IF done THEN
LEAVE read_loop;
END IF;
UPDATE mem_card_extend a SET total_fill_self_money=IFNULL((SELECT SUM(adjust_money) FROM mem_card_money_flow f WHERE (money_operate_type=2 OR money_operate_type=4) AND status_code=1 AND f.card_id=v_card_id),0) WHERE a.card_id=v_card_id;  -- 累计充值本金
UPDATE mem_card_extend a SET total_fill_give_money=IFNULL((SELECT SUM(adjust_give_money) FROM mem_card_money_flow f WHERE money_operate_type=4 AND status_code=1 AND f.card_id=v_card_id),0) WHERE a.card_id=v_card_id; -- 累计充值赠送
UPDATE mem_card_extend a SET total_adjust_self_money=IFNULL((SELECT SUM(adjust_money) FROM mem_card_money_flow f WHERE money_operate_type=3 AND status_code=1 AND f.card_id=v_card_id),0) WHERE a.card_id=v_card_id; -- 累计调整本金
UPDATE mem_card_extend a SET total_adjust_give_money=IFNULL((SELECT SUM(adjust_give_money) FROM mem_card_money_flow f WHERE money_operate_type=3 AND status_code=1 AND f.card_id=v_card_id),0) WHERE a.card_id=v_card_id; -- 累计调整赠送
UPDATE mem_card_extend a SET total_score_fill_self_money=IFNULL((SELECT SUM(adjust_money) FROM mem_card_money_flow f WHERE money_operate_type=5 AND status_code=1 AND f.card_id=v_card_id),0) WHERE a.card_id=v_card_id; -- 累计积分兑换本金
UPDATE mem_card_extend a SET total_score_fill_give_money=IFNULL((SELECT SUM(adjust_give_money) FROM mem_card_money_flow f WHERE money_operate_type=5 AND status_code=1 AND f.card_id=v_card_id ),0) WHERE a.card_id=v_card_id; -- 累计积分兑换赠送
END LOOP;
CLOSE cur;
END$$
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: