大表分批删除脚本之MySQL版

2018-06-17 23:31:34来源:未知 阅读 ()

新老客户大回馈,云服务器低至5折

经常需要定期对某些表删除历史数据,通常这样的表的数据又是非常巨大,为了减轻对线上环境的影响,删除时必须分成小批量来进行。

以前分享过SQLServer的版本。

下面是MySQL版本:

 1 delimiter $$
 2 drop procedure if exists proc_delete_old_data;
 3 create procedure proc_delete_old_data()
 4 begin
 5 lp : loop
 6     delete from mytable where createdtime <= date_sub(curdate(),interval 1 month) limit 5000;
 7     if row_count() < 5000 then
 8         leave lp;
 9     end if;
10     select sleep(1);
11 end loop;
12 end $$
13 
14 delimiter ;
15 set binlog_format = STATEMENT;
16 call proc_delete_old_data;

本文地址:http://www.cnblogs.com/ajiangg/p/6604317.html

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:Mysql日期和字符的相互转换

下一篇:sphinx安装