mysql存储过程中使用临时表和游标
Posted 疯狂的多多
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql存储过程中使用临时表和游标相关的知识,希望对你有一定的参考价值。
1。临时表
1 DROP PROCEDURE 2 IF EXISTS `P_GetMonitorPeople`; 3 CREATE PROCEDURE P_GetMonitorPeople (IN fgid INT, IN mins INT,in lens INT) 4 BEGIN 5 IF fgid>0&&mins>0&&lens>0 THEN 6 BEGIN 7 -- 建表tb_temp1 8 DROP TABLE IF EXISTS tb_temp1; 9 CREATE TEMPORARY TABLE tb_temp1( 10 `Tmp_Id` int UNSIGNED NOT NULL AUTO_INCREMENT, 11 `GatherID` int NOT NULL, 12 `PhoneMac` varchar(12) NOT NULL, 13 `number` int NOT NULL, 14 PRIMARY KEY (`Tmp_Id`) 15 ) ENGINE = MYISAM DEFAULT charset = utf8; 16 -- 填充tb_temp1 17 INSERT into tb_temp1(GatherID,PhoneMac,number) 18 select gatherid, phonemac,count(phonemac) as number from ( 19 select DISTINCT s.GatherID,s.phonemac from tb_app_gather_mac_shot s 20 LEFT JOIN tb_web_config_gather g on g.gatherid=s.gatherid 21 where s.logtime BETWEEN DATE_SUB(NOW(),INTERVAL mins MINUTE) and NOW() and g.floorid=(select floorid from tb_web_floors where groupid=fgid) 22 ORDER BY s.logtime) as tb GROUP BY phonemac order by number DESC LIMIT lens; 23 24 select DISTINCT g.gatherid, t.phonemac,g.locationx,g.locationy from tb_temp1 t 25 LEFT JOIN tb_web_config_gather g on g.gatherid=t.gatherid; 26 END; 27 END IF; 28 #销毁内存表 29 DROP TABLE IF EXISTS tb_temp1; 30 END 31 32 -- 显示 33 CALL P_GetMonitorPeople(3,1,50);
2。游标
DROP PROCEDURE IF EXISTS P_GetMonitorData; CREATE PROCEDURE P_GetMonitorData(fgid int,mins int,lens int,mac varchar(12)) BEGIN DECLARE tmpid int ; DECLARE gid varchar(10) ; DECLARE done INT DEFAULT FALSE; DECLARE pregatherid int DEFAULT 0; DECLARE str VARCHAR(200); -- 定义游标 DECLARE rs CURSOR for select Tmp_Id,GatherID from tb_temp2; -- 错误定义,标记循环结束 DECLARE CONTINUE HANDLER FOR NOT FOUND SET done=TRUE; -- 打开游标 OPEN rs; -- 循环执行 REPEAT FETCH rs into tmpid,gid ; IF NOT done THEN #执行操作 IF pregatherid=gid && pregatherid <> 0 THEN DELETE from tb_temp2 where Tmp_Id=tmpid; ELSE SET pregatherid=gid; -- SET str=CONCAT(gid,str); END IF; END IF; #当_done=FALSE时退出被循 UNTIL done END REPEAT; /*关闭游标*/ CLOSE rs; select * from tb_temp2; SET done=FALSE;#只有定义为false,新的循环才能继续。 END
以上是关于mysql存储过程中使用临时表和游标的主要内容,如果未能解决你的问题,请参考以下文章