Mysql自动按月表分区

news/2024/7/3 0:02:21 标签: mysql

很久没有碰DB了。最近需要做一个日志表,因此重新拾了下。实现了下自动按月表分区
开发环境为Mysql 5.7.28

参考资料:
Mysql分区表及自动创建分区Partition(按日)

核心的两个存储过程:
auto_create_partition为创建表分区,调用后为该表创建到下月结束的表分区。
auto_del_partition为删除表分区,方便历史数据空间回收。

DELIMITER $$
DROP PROCEDURE IF EXISTS auto_create_partition$$
CREATE PROCEDURE `auto_create_partition`(IN `table_name` varchar(64))
BEGIN
			SET @next_month:=CONCAT(date_format(date_add(now(),interval 2 month),'%Y%m'),'01');
			SET @SQL = CONCAT( 'ALTER TABLE `', table_name, '`',
					' ADD PARTITION (PARTITION p', @next_month, " VALUES LESS THAN (TO_DAYS(",
							@next_month ,")) );" );
			PREPARE STMT FROM @SQL;
			EXECUTE STMT;
			DEALLOCATE PREPARE STMT;
END$$

DROP PROCEDURE IF EXISTS auto_del_partition$$
CREATE PROCEDURE `auto_del_partition`(IN `table_name` varchar(64),IN `reserved_month` int)
BEGIN
	DECLARE v_finished INTEGER DEFAULT 0;
	DECLARE v_part_name varchar(100) DEFAULT "";
	DECLARE part_cursor CURSOR FOR 
		select partition_name from information_schema.partitions where table_schema = schema()
			and table_name=@table_name and partition_description < TO_DAYS(CONCAT(date_format(date_sub(now(),interval reserved_month month),'%Y%m'),'01'));
	DECLARE continue handler FOR 
		NOT FOUND SET v_finished = TRUE;
	OPEN part_cursor;
read_loop: LOOP
	FETCH part_cursor INTO v_part_name;
	if v_finished = 1 then
		leave read_loop;
	end if;
	SET @SQL = CONCAT( 'ALTER TABLE `', table_name, '` DROP PARTITION ', v_part_name, ";" );
	PREPARE STMT FROM @SQL;
	EXECUTE STMT;
	DEALLOCATE PREPARE STMT;
	END LOOP;
	CLOSE part_cursor;
END$$

DELIMITER ;

下面是示例

-- 假设有个表叫records,设置分区条件为按end_time按月分区
DROP TABLE IF EXISTS `records`;
CREATE TABLE `records` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `start_time` datetime NOT NULL,
  `end_time` datetime NOT NULL,
  `memo` varchar(128) CHARACTER SET utf8mb4 NOT NULL,
  PRIMARY KEY (`id`,`end_time`)
) 
PARTITION BY RANGE (TO_DAYS(end_time))(
	PARTITION p20200801 VALUES LESS THAN ( TO_DAYS('20200801'))
);

DROP EVENT IF EXISTS `records_auto_partition`;

-- 创建一个Event,每月执行一次,同时最多保存6个月的数据
DELIMITER $$
CREATE EVENT `records_auto_partition`
ON SCHEDULE EVERY 1 MONTH ON COMPLETION PRESERVE
ENABLE
DO
BEGIN
call auto_create_partition('records');
call auto_del_partition('records',6);
END$$
DELIMITER ;

几点注意事项:

  • 对于Mysql 5.1以上版本来说,表分区的索引字段必须是主键
  • 存储过程中,DECLARE 必须紧跟着BEGIN,否则会报看不懂的错误
  • 游标的DECLARE需要在定义声明之后,否则会报错
  • 如果是自己安装的Mysql,有可能Event功能是未开启的,在创建Event时会提示错误;修改my.cnf,在 [mysqld] 下添加event_scheduler=1后重启即可。

http://www.niftyadmin.cn/n/1335561.html

相关文章

小程序创业最后的红利期

从 2017 年初&#xff0c;微信创始人张小龙宣布小程序正式上线开始&#xff0c;很多行业都在摸索着开发小程序&#xff0c;且取得了不错的成绩&#xff0c;小程序已经生长出一个相对完整的生态圈。 在这个生态圈内&#xff0c;基于去中心化的特点&#xff0c;依托微信入口省去了…

怎么把avi格式转换成mp4?用电脑转换avi格式的方法

提起视频格式相比大家首先想到的就是mp4格式&#xff0c;而往往容易忘记avi格式。而mp4格式相比avi格式由于其占用内存相对较小且兼容性相对较高的特点而成为无人不晓的视频格式。因此很多人想把占用内存相对较大的avi格式转换成mp4。下面小编就教你用迅捷视频转换器把avi格式转…

LinuxX86中打印堆栈的简易使用说明

在某些多路径的函数&#xff08;例如退出&#xff09;&#xff0c;我们希望通过在日志中打印堆栈&#xff0c;确认调用途径&#xff0c;以定位一些奇怪的业务逻辑问题。 在Linux中&#xff0c;我们可以使用backtrace函数进行追踪。 *Android不支持此方法 1.使用示例 *以下代码…

学习 python 的 pytest 框架需要的基础知识和学习准备

学习 python 的 pytest 框架需要的基础知识和学习准备测试从业者学习 python 应该掌握的内容: 首先是变量和数据类型&#xff0c;其次列表、字典以及 Json 的一些处理&#xff0c;再者就是循环 判断以及函数或类这些内容。 其中的重点&#xff1a; 1.循环判断以及字典这块是重点…

分享5个高质无损音乐网站,歌曲很丰富,爱听歌的小伙伴有耳福了

生活中很多人都离不开音乐&#xff0c;散步的时候听音乐&#xff0c;等待的时候听着音乐&#xff0c;心情不好的时候听音乐&#xff0c;不管走到哪&#xff0c;有音乐的陪伴一点也不寂寞&#xff0c;不同音乐的旋律给我们带来不同的心情&#xff0c;今天小编就给爱听音乐的小伙…

简易DOCKER/K8S使用心得

1. DOCKER安装 1.1 前置环境 首先&#xff0c;如果使用CentOS&#xff0c;你至少需要7.4以上。从内核角度来说&#xff0c;建议使用8.2及以上。 如果是7.4以下的版本&#xff0c;可以通过设置仓库到7.4以上版本&#xff0c;再 yum install centos-release kernel #实际上安装…

动画---分块运动

动画---分块运动 package com.example.test;import android.content.Context; import android.graphics.Bitmap; import android.graphics.BitmapFactory; import android.graphics.Canvas; import android.graphics.Color; import android.graphics.Paint; import android.gra…

爬虫进阶 -- 神级程序员:让你的爬虫就像人类的用户行为!

1 前言近期&#xff0c;有些朋友问我一些关于如何应对反爬虫的问题。由于好多朋友都在问&#xff0c;因此决定写一篇此类的博客。把我知道的一些方法&#xff0c;分享给大家。博主属于小菜级别&#xff0c;玩爬虫也完全是处于兴趣爱好&#xff0c;如有不足之处&#xff0c;还望…