一、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