数据库
首页 > 数据库> > mysql 存储过程 使用内存表代替游标

mysql 存储过程 使用内存表代替游标

作者:互联网

一、MySQL游标的概念
1、游标介绍
MySQL的游标(cursor)是一个重要的概念,通过查找资料与自己的理解,主要得出以下几点关于自己的理解。

有数据缓冲的思想:游标的设计是一种数据缓冲区的思想,用来存放SQL语句执行的结果。 先有数据基础:游标是在先从数据表中检索出数据之后才能继续灵活操作的技术。 类似于指针:游标类似于指向数据结构堆栈中的指针,用来pop出所指向的数据,并且只能每次取一个。
游标的缺点是针对有点而言的,也就是只能一行一行操作,在数据量大的情况下,是不适用的,速度过慢。这里有个比喻就是:当你去ATM存钱是希望一次性存完呢,还是100一张一张的存,这里的100一张一张存就是游标针对行的操作。 数据库大部分是面对集合的,业务会比较复杂,而游标使用会有死锁,影响其他的业务操作,不可取。 当数据量大时,使用游标会造成内存不足现象。那这个时候我们可以内存表来解决这个问题,还是置接上sql把,也是第一次写,希望大家不要喷

BEGIN
– 定义变量
DECLARE order_count INT; – 数量
DECLARE area_intro CHAR(50); – 区域
DECLARE count_time DATETIME;
DECLARE maxId INT DEFAULT 0;
DECLARE i INT DEFAULT 0;
– 先销毁临时表
DROP TABLE IF EXISTS count_order_statistics_temp;
– 创建临时表
CREATE TEMPORARY TABLE count_order_statistics_temp(
id INT(11) NOT NULL AUTO_INCREMENT,
order_count INT(11) DEFAULT ‘0’ COMMENT ‘订单数量’,
area_intro CHAR(50) DEFAULT NULL COMMENT ‘区域’,
count_time DATETIME DEFAULT NULL COMMENT ‘统计时间’,

        PRIMARY KEY (`id`)  
    )ENGINE=MYISAM DEFAULT CHARSET=utf8; 
     INSERT INTO count_order_statistics_temp(order_count,area_intro,count_time)

SELECT
IFNULL(COUNT(1),‘0’)order_count,m.area_intro,DATE_FORMAT(NOW(),’%Y-%m-%d’)count_time FROM user_judge j
LEFT JOIN merchant m ON m.id=j.merchant_id
WHERE j.state<>8 AND TO_DAYS(NOW()) = TO_DAYS(j.begin_time) GROUP BY m.area_intro;
– 查询临时表最大的id
SELECT MAX(id) INTO maxId FROM count_order_statistics_temp;
SELECT MIN(id) INTO i FROM count_order_statistics_temp;
– 开始循环
WHILE i <= maxId DO
SELECT order_count, area_intro,DATE_FORMAT(NOW(),’%Y-%m-%d’) INTO order_count, area_intro,count_time FROM count_order_statistics_temp WHERE id = i;
SET i = i + 1;
END WHILE;
END$$

DELIMITER ;


到这里存储过程就写完成啦,然后运行,如果不报错的话就可以调用存储过程啦
然后调用存储过程 使用 call 存储过程名称,调用成功后,查询刚才统计的数据使用 select  字段名称  from  临时表名称 。有哪里不对的地方还希望各位能帮忙指出,谢谢!
**本文借鉴啦下面大神的博客:**https://www.cnblogs.com/tonykan/archive/2012/11/28/2793807.html





标签:count,area,游标,order,intro,内存,mysql,id
来源: https://blog.csdn.net/qq_38829237/article/details/113701583