mysql 存储过程 使用内存表代替游标
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了mysql 存储过程 使用内存表代替游标,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2358字,纯文字阅读大概需要4分钟。
内容图文
![mysql 存储过程 使用内存表代替游标](/upload/InfoBanner/zyjiaocheng/865/e4ed666b7f77455f95f862b768649c28.jpg)
一、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
内容总结
以上是互联网集市为您收集整理的mysql 存储过程 使用内存表代替游标全部内容,希望文章能够帮你解决mysql 存储过程 使用内存表代替游标所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。