欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Mysql - 存储过程 - 定时删表

程序员文章站 2023-11-15 18:49:40
在工业监控里面, 需要对每天的数据, 进行记录, 时间长了之后, 数据库很容易撑爆. 这时候, 如果允许, 可以对之前的数据进行一次清除, 只记录几个月内的数据. 在数据库中, 进行测试: 执行脚本: 会发现, 表确实被删除了, 且别的表并未受到影响. 在不能发后台包的情况下, 可以通过mysql定 ......

在工业监控里面, 需要对每天的数据, 进行记录, 时间长了之后, 数据库很容易撑爆. 这时候, 如果允许, 可以对之前的数据进行一次清除, 只记录几个月内的数据.

delimiter $
drop procedure  if exists p_clearolddata;
/*
g_date_limit 时间限制, 如 2019_08 , 则删除 该时间之前的表 
g_date_length 时间格式的长度, 如 后缀时间是 2019_08, 则此处应该传 7  
*/
create procedure  p_clearolddata(in g_date_limit varchar(30), in g_date_length int ) 
begin 
    /*查询到的表名*/
    declare g_table varchar(100);

    /*查询到的表名对应的后缀时间*/
    declare g_date varchar(30) default '';

    /*定义done, 用于跳出循环使用*/
    declare done bit default 0;

    /*声明游标*/
    declare g_cursor cursor for select table_name from information_schema.tables  where table_schema='tt_abc' and table_name like 't_bk001_%';

    /*游标查询时, 如果找不到下一个了, 会将done置为1, 用于跳出 repeat 循环*/
  declare continue handler for not found set done = 1;

    /* 待执行动态sql */
    set @v_full_sql := '';

    /*打开游标*/
    open g_cursor;

    repeat

        fetch g_cursor into g_table;

        set g_date = right(g_table, g_date_length);

        if g_date < g_date_limit then 

            set @v_full_sql = concat('drop table if exists ',g_table);

             /*预编译此动态sql, 并存入stmt中*/
            prepare stmt from @v_full_sql;

            /*执行此动态sql, 此动态sql的作用, 是删除表*/
            execute stmt;    

            /*释放此资源*/
            deallocate prepare stmt;

        end if;

    /*结束repeat循环*/
    until done end repeat; 

    /*关闭游标*/
    close g_cursor;

select 'ok';

end $
delimiter;

在数据库中, 进行测试:

create table `t_bk001_2019_02` (
  `id` int(11) not null auto_increment,
  primary key (`id`)
) engine=innodb default charset=utf8

执行脚本:

call p_clearolddata('2019_03', 7);

会发现, 表确实被删除了, 且别的表并未受到影响.

在不能发后台包的情况下, 可以通过mysql定时任务和存储过程, 来实现定时删表操作. 

不过, 如果通过这种方式, 还需要对此存储过程进行改动, 或者再创建一个存储过程, 对此进行封装成一个没有参数的存储过程.

 

*注:

以上操作, 不推荐在mysql中, 通过定时任务和存储过程来实现此功能, 推荐通过后台定时任务, 执行删表操作.