Mysql - 存储过程 - 定时删表

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: Mysql - 存储过程 - 定时删表在工业监控里面, 需要对每天的数据, 进行记录, 时间长了之后, 数据库很容易撑爆. 这时候, 如果允许, 可以对之前的数据进行一次清除, 只记录几个月内的数据.

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中, 通过定时任务和存储过程来实现此功能, 推荐通过后台定时任务, 执行删表操作.
原文地址https://www.cnblogs.com/elvinle/p/11444781.html

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
21天前
|
存储 SQL 关系型数据库
轻松入门MySQL:加速进销存!利用MySQL存储过程轻松优化每日销售统计(15)
轻松入门MySQL:加速进销存!利用MySQL存储过程轻松优化每日销售统计(15)
|
1月前
|
存储 关系型数据库 MySQL
Mysql基础第二十六天,使用存储过程
Mysql基础第二十六天,使用存储过程
28 0
Mysql基础第二十六天,使用存储过程
|
1月前
|
存储 SQL 关系型数据库
【MySQL 数据库】9、存储过程
【MySQL 数据库】9、存储过程
205 0
|
15天前
|
存储 SQL 关系型数据库
mysql存储过程示例
mysql存储过程示例
11 0
|
2月前
|
关系型数据库 MySQL Linux
Linux环境下定时备份mysql数据库
Linux环境下定时备份mysql数据库
|
2月前
|
存储 SQL 关系型数据库
[MySQL]存储过程
[MySQL]存储过程
76 0
[MySQL]存储过程
|
2月前
|
存储 关系型数据库 MySQL
MySQL 中的存储过程-3
MySQL 中的存储过程
20 0
|
2月前
|
存储 SQL 关系型数据库
MySQL 中的存储过程-2
MySQL 中的存储过程
18 0
|
3月前
|
存储 关系型数据库 MySQL
MySQL-调用存储过程
MySQL-调用存储过程
101 2
|
3月前
|
存储 关系型数据库 MySQL
MySQL 中创建存储过程
MySQL 中创建存储过程
24 1