网站首页 > 基础教程 正文
平时工作中所遇到的问题,今天为大家整理一下,废话不多说,直接上代码
建立存储过程后,需创建Mysql定时任务,来每天自动执行,我自动的版本,默认晚上11点自动调用存储过程
注:如表中存在数据,必须手动对已有数据建立分区,且分区为主键或者联合主键,下面直接贴代码,可根据自己实际情况进行修改。
-- 增加新分区
-- 不同于insert into A select from B,A必须存在。
SELECT max(cast(replace(partition_description, '''', '') AS date)) AS val
INTO v_maxdate
FROM INFORMATION_SCHEMA.PARTITIONS
WHERE TABLE_NAME = 'tb_visit' AND TABLE_SCHEMA = 'fzmy'; # 目标表 数据库实例名称,根据实际情况添加
set v_sysdate = sysdate(); # 赋值v_sysdate为当前时间
-- INTERVAL 时间计算的关键字
-- 当前写法默认创建三天后的分区表 可更改
WHILE v_maxdate <= (v_sysdate + INTERVAL 1 DAY) DO
SET v_pt = date_format(v_maxdate + INTERVAL 1 DAY , '%Y%m%d');
SET v_maxval = v_maxdate + INTERVAL 2 DAY;
SET add_sql = concat('alter table tb_visit add partition (partition p', v_pt, ' values less than(''', v_maxval, '''))'); # tb_visit 目标表,根据实际情况修改
SET @sql=add_sql;
PREPARE stmt FROM @sql; # 分配给这条SQL语句一个名字供之后调用
EXECUTE stmt; # 命令执行
DEALLOCATE PREPARE stmt; # 执行完后,释放掉
SET v_maxdate = v_maxdate + INTERVAL 1 DAY; # 最大值 加一操作
END WHILE;
-- 查找最早的分区
SELECT min(cast(replace(partition_description, '''', '') AS date)) AS val
INTO v_mindate
FROM INFORMATION_SCHEMA.PARTITIONS
WHERE TABLE_NAME = 'tb_visit' AND TABLE_SCHEMA = 'fzmy';# tb_visit 目标表,根据实际情况修改
-- 删除30天前的旧分区
WHILE v_mindate <= (v_sysdate - INTERVAL 30 DAY) DO
SET v_pt = date_format(v_mindate , '%Y%m%d');
SET del_sql = concat('alter table tb_visit drop partition p', v_pt); # tb_visit 目标表,根据实际情况修改
set @sql=del_sql;
PREPARE stmt FROM @sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
SET v_mindate = v_mindate + INTERVAL 1 DAY;
END WHILE;
END
------------------------------------- 此处为分界线 -------------------------------------------
-- 创建定时任务
create event ceshi_partition # 定时任务名称
-- 每天晚上23点执行(待验证)
ON SCHEDULE EVERY 1 DAY STARTS DATE_ADD(DATE_ADD(CURDATE(), INTERVAL 1 DAY), INTERVAL 23 HOUR)
on completion preserve disable
do call p_partition_test(); # 调用存储过程,此处为存储过程名称
- 上一篇: MySQL常用函数,程序员真得看看
- 下一篇: MySQL时间、字符串、戳的转换
猜你喜欢
- 2024-12-03 mysql中的date、datetime、timestamp你还不知道怎么使用吗
- 2024-12-03 线程不安全的 SimpleDateFormat
- 2024-12-03 MySQL中按月统计并逐月累加统计值的几种写法
- 2024-12-03 最全的MySQL时间函数总结
- 2024-12-03 MySQL数据库关于表的一系列操作
- 2024-12-03 Mysql 设置自动每个月生成分区方法
- 2024-12-03 浅谈分库分表那些事儿
- 2024-12-03 mysql数据库创建分区表,并且自动创建新分区的保姆教程
- 2024-12-03 MySQL与SQL SERVER周指标计算
- 2024-12-03 date命令及格式化详解
- 最近发表
- 标签列表
-
- gitpush (61)
- pythonif (68)
- location.href (57)
- tail-f (57)
- pythonifelse (59)
- deletesql (62)
- c++模板 (62)
- css3动画 (57)
- c#event (59)
- linuxgzip (68)
- 字符串连接 (73)
- nginx配置文件详解 (61)
- html标签 (69)
- c++初始化列表 (64)
- exec命令 (59)
- canvasfilltext (58)
- mysqlinnodbmyisam区别 (63)
- arraylistadd (66)
- node教程 (59)
- console.table (62)
- c++time_t (58)
- phpcookie (58)
- mysqldatesub函数 (63)
- window10java环境变量设置 (66)
- c++虚函数和纯虚函数的区别 (66)