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

以前分享过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

相关文章:

  • 2022-12-23
  • 2021-11-30
  • 2022-01-27
  • 2022-12-23
  • 2022-12-23
  • 2021-12-04
  • 2022-12-23
  • 2022-12-23
猜你喜欢
  • 2021-10-20
  • 2022-12-23
  • 2021-06-21
  • 2022-12-23
  • 2021-11-30
  • 2021-11-30
相关资源
相似解决方案