MySQL定期自动删除表

此文转自ITPUB上一位大哥, 此为传送门
单位8亿多条的日志表,经过自动分表之后,需要自动删除30天前创建的日志表。
但是只是在Master下线这些日志表,而Slave还需要保持在线,以备查询。
http://blog.itpub.net/29254281/viewspace-1141985/

由于Master-Slave结构,在Drop表之前,设置@@session.sql_log_bin=0,那么Drop的行为就没有记录到binlog,所以Slave的日志表就会被保留。

模拟环境如下,

  1. mysql> show tables;
  2. +---------------------------------+
  3. | Tables_in_edmond |
  4. +---------------------------------+
  5. | sod_song_log_2014_1_22_13_18_20 |
  6. | sod_song_log_2014_2_22_13_18_20 |
  7. | sod_song_log_2014_3_22_13_18_20 |
  8. | sod_song_log_2014_4_22_13_18_20 |
  9. +---------------------------------+
  10. 4 rows in set (0.00 sec)
过程如下:

  1. delimiter $$
  2. CREATE procedure drop_table()
  3. BEGIN
  4.             declare t_name varchar(64);
  5.             declare isFinished int default false;
  6.             declare log_table_list cursor for (select table_name frominformation_schema.tables where table_schema = 'EDMOND' and table_name like 'sod_song_log_%');
  7.             declare continue handler for not found set isFinished=true; 
  8.             open log_table_list;
  9.             repeat 
  10.                 fetch log_table_list into t_name; 
  11.                 if isFinished = false then
  12.                     if datediff(now(),replace(t_name,'sod_song_log_',''))>30 then
  13.                         set @@session.sql_log_bin=0;
  14.                         set @sqltext=concat('drop table ',t_name,';');
  15.                         PREPARE c_tab_stat from @sqltext;
  16.                         execute c_tab_stat; 
  17.                         set @@session.sql_log_bin=1;
  18.                     end if;
  19.                 end if;
  20.                 until isFinished 
  21.             end repeat; 
  22.             close log_table_list;
  23. END $$
  24. delimiter ;
执行过程,结果如下

  1. mysql> call drop_table();
  2. Query OK, 0 rows affected (0.28 sec)

  3. mysql> show tables;
  4. +---------------------------------+
  5. | Tables_in_edmond |
  6. +---------------------------------+
  7. | sod_song_log_2014_4_22_13_18_20 |
  8. +---------------------------------+
  9. 1 row in set (0.00 sec)

  10. mysql> select now() from dual;
  11. +---------------------+
  12. | now() |
  13. +---------------------+
  14. | 2014-04-22 17:58:24 |
  15. +---------------------+
  16. 1 row in set (0.00 sec)
并且binlog中没有记录这个Drop的行为。
配合Linux crontab即可实现定期自动删除表的功能。

一定不要把 sql_log_bin设置为global级别,不能犯迷糊
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
MySQL 定期删除数据可以使用以下两种方法: 1. 使用 MySQL 事件调度器 MySQL 事件调度器可以在指定的时间间隔内自动执行指定的 SQL 语句。可以使用以下步骤来定期删除数据: - 创建一个存储过程,该存储过程包含要执行的 SQL 语句。 - 创建一个事件,该事件包含存储过程和执行的时间间隔。 - 启用事件调度器。 以下是一个示例存储过程和事件: ``` DELIMITER $$ CREATE PROCEDURE delete_old_data() BEGIN DELETE FROM my_table WHERE created_date < DATE_SUB(NOW(), INTERVAL 30 DAY); END$$ DELIMITER ; CREATE EVENT delete_data_event ON SCHEDULE EVERY 1 DAY STARTS '2022-01-01 00:00:00' DO BEGIN CALL delete_old_data(); END; ``` 上述代码将创建一个名为 `delete_old_data` 的存储过程,该存储过程将删除 `my_table` 表中创建时间早于 30 天前的所有数据。然后,创建一个名为 `delete_data_event` 的事件,该事件每天执行一次,并在 2022 年 1 月 1 日开始执行。 2. 使用 cron 任务 在 Linux 系统上,可以使用 cron 任务来定期运行 MySQL删除数据命令。可以使用以下步骤来设置 cron 任务: - 创建一个 shell 脚本,该脚本包含要执行的 SQL 语句。 - 使用 crontab 命令来创建一个定时任务,指定要运行的 shell 脚本和执行的时间间隔。 以下是一个示例 shell 脚本和 cron 任务: ``` #!/bin/bash mysql -u username -p password -e "DELETE FROM my_table WHERE created_date < DATE_SUB(NOW(), INTERVAL 30 DAY);" # crontab -e 0 0 * * * /path/to/script.sh ``` 上述代码将创建一个名为 `script.sh` 的 shell 脚本,该脚本将删除 `my_table` 表中创建时间早于 30 天前的所有数据。然后,使用 `crontab -e` 命令来添加一个 cron 任务,该任务每天执行一次。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值