MySQL 定时新增分区的实现示例

 更新时间:2025年07月03日 15:38:23   作者:二宝哥  
本文主要介绍了通过存储过程和定时任务实现MySQL分区的自动创建,解决大数据量下手动维护的繁琐问题,具有一定的参考价值,感兴趣的可以了解一下

MySQL创建好分区之后,有时候会需要自动创建分区。比如,一些表数据量非常大,有些数据是热点数据,按照日期分区后,业务量还在走,就会需要过段时间再创建一次分区。身为程序员总是手动创建不能忍。

首先创建一个存储过程,可以自动新增分区(如果需要自动删除分区,本文同样适用)

DELIMITER $$
USE `me`$$
CREATE DEFINER=`root`@`localhost` PROCEDURE `add_schedule_log_partition`()
BEGIN
set @pname = concat('p',date_format(curdate(),'%Y%m%d'));
set @nexttodays = to_days(date_add(curdate(), INTERVAL 1 DAY));
set @executeStr = concat('alter table s_schedule_log add partition (PARTITION ',  @pname, ' VALUES LESS THAN (', @nexttodays, ' ))');
prepare stmt from @executeStr;
execute stmt;
deallocate prepare stmt;
select @executeStr;
END$$

DELIMITER ;
;

存储过程可以手动call下,有没有问题。然后写个定时任务

DELIMITER ||
CREATE EVENT add_schedule_log_partition_event
          ON SCHEDULE
          EVERY 1 day STARTS '2022-05-15 01:00:00'
          DO
      BEGIN
          call `me`.`add_schedule_log_partition`;
 END ||
DELIMITER ;

注意:定时任务需要参数event_scheduler开启状态,使用sql:show variables like '%schedule%' 查看状态。

 开启任务状态:set global event_scheduler = 'ON'

通过存储过程和定时任务实现MySQL分区的自动创建,解决大数据量下手动维护的繁琐问题,

相关文章

  • MySQL高级篇之索引的数据结构详解

    MySQL高级篇之索引的数据结构详解

    在MySQL中索引属于存储引擎级别的概念,不同存储引擎对索引的实现方式是不同的,下面这篇文章主要给大家介绍了关于MySQL高级篇之索引数据结构的相关资料,需要的朋友可以参考下
    2022-05-05
  • mysql日期处理函数实例解析

    mysql日期处理函数实例解析

    这篇文章主要介绍了mysql日期处理函数实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-12-12
  • CentOS系统中MySQL安装完整步骤详解

    CentOS系统中MySQL安装完整步骤详解

    在 CentOS 系统上安装 MySQL,需要依次进行环境检查、软件源配置、安装 MySQL、启动服务等操作,我将按照规范流程,为你详细分享完整且具体的安装步骤,感兴趣的朋友一起看看吧
    2025-04-04
  • Mysql 5.7.17忘记密码怎么办

    Mysql 5.7.17忘记密码怎么办

    这篇文章主要介绍了Mysql 5.7.17忘记密码的解决方法,需要的朋友可以参考下
    2017-03-03
  • MySQL中WITH用法小结

    MySQL中WITH用法小结

    WITH子句是MySQL中的一种SQL结构,本文主要介绍了MySQL中WITH用法小结,具有一定的参考价值,感兴趣的可以了解一下
    2023-10-10
  • mysql split函数用逗号分隔的实现

    mysql split函数用逗号分隔的实现

    这篇文章主要介绍了mysql split函数用逗号分隔的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-10-10
  • MySQL 发生同步延迟时Seconds_Behind_Master还为0的原因

    MySQL 发生同步延迟时Seconds_Behind_Master还为0的原因

    腾讯云数据库 MySQL 的只读实例出现了同步延迟,但是监控的延迟时间显示为 0,而且延迟的 binlog 距离非 0,且数值越来越大。临时解决之后,仔细想了一想,Seconds_Behind_Master 虽然计算方式有点坑,但是出现这么“巨大”的误差还是挺奇怪的,本文就来分析下这个问题
    2021-06-06
  • MySQL索引查询的具体使用

    MySQL索引查询的具体使用

    本文主要介绍了MySQL索引查询的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-05-05
  • MySQL变更缓冲区作用、主要配置及查看方法

    MySQL变更缓冲区作用、主要配置及查看方法

    变更缓冲区用来缓存对二级索引数据的修改,当数据页没有被回载到内存中时,先把修改缓存起来,等到其他查询操作发生时,数据页被加载到内存后,再直接修改内存中的数据页,从而达到减少磁盘I/0的目的,下面给大家介绍MySQL变更缓冲区及查看方法,感兴趣的朋友一起看看吧
    2025-05-05
  • MySQL关键字Distinct的详细介绍

    MySQL关键字Distinct的详细介绍

    这篇文章主要介绍了MySQL关键字Distinct的详细介绍的相关资料,需要的朋友可以参考下
    2017-07-07

最新评论