热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

mysql动态新建以及删除分区表_MySQL

mysql动态新建以及删除分区表
bitsCN.com

mysql动态新建以及删除分区表

因为项目需要,最近研究了一下在mysql数据库下如何动态新建以及删除分区表。如果全部借助存储过程的话,新建以及删除分区表在逻辑上比较死板、不灵活,而且还容易出错。因此,我新建了一个数据表table_fen_qu,借助这个表可以很(相对)灵活的对分区表进行管理。以下是操作过程,不足之处请各位看官指正。

第一步:建立存储过程。

建立新建分区表的存储过程代码如下:

001

drop procedure if exists general_procedure;

002

-- general_procedure的作用:新建分区表及在table_fen_qu表中存储新建分区表时的相关参数

003

-- general_procedure的参数:表名,分区表之间的时间间隔(单位为小时),要新增的分区表个数

004

create procedure general_procedure(in tablenamein varchar(50),in intervalHour int,in newIntervalNum int)

005

general_pro:begin

006

-- 参数:最大时间

007

declare maxMonitTime datetime default SYSDATE();

008

-- 参数:最大时间对应的字符串

009

declare maxMonitTimeStr varchar(50);

010

-- 参数:最小时间

011

declare minMonitTime datetime default SYSDATE();

012

-- 参数:最大时间对应的字符串

013

declare minMonitTimeStr varchar(50);

014

-- 参数:数据库记录数

015

declare recoidNum int default 0;

016

-- 判断传入的表名是否为空

017

if tablenamein is null then

018

leave general_pro;

019

end if;

020

-- 判断传入的时间间隔

021

if intervalHour <= 0 then

022

set intervalHour = 6;

023

end if;

024

-- 判断新增分区表个数

025

if newIntervalNum <= 0 then

026

set newIntervalNum = 1;

027

end if;

028

029

-- 在该表中,查询符合条件的记录数,backupflag=0说明是未备份

030

select count(*) into recoidNum from table_fen_qu where tablename=tablenamein and backupflag=0;

031

if recoidNum > 0 then

032

-- 查询该表在table_fen_qu表中的最大监测时间

033

select monittime into maxMonitTime from table_fen_qu where tablename=tablenamein and backupflag=0 order by monittime desc limit 1;

034

-- 判断监测时间是否为null

035

if maxMonitTime is null then

036

set maxMOnitTime= SYSDATE();

037

end if;

038

-- 比较最大时间减去72个小时之后的时间与系统时间的早晚

039

set recoidNum = timestampdiff(hour,SYSDATE(),DATE_SUB(maxMonitTime,INTERVAL 3 DAY));

040

-- 如果recoidNum大于0,说明最大监测时间减去72小时之后的时间仍然在系统时间之后,

041

-- 说明不用建立新的分区表,反之,则建立最大监测时间之后newIntervalNum个以每intervalHour小时为间隔的分区表

042

if recoidNum <= 0 then

043

set recoidNum = 1;

044

while recoidNum <= newIntervalNum do

045

set maxMOnitTime= ADDDATE(maxMonitTime,INTERVAL intervalHour HOUR);

046

set maxMOnitTimeStr= CONCAT(&#39;p&#39;,DATE_FORMAT(maxMonitTime,"%Y%m%d%H%i%s"));

047

-- 开始添加分区表

048

/*拼接分区表代码段*/

049

set @v_add_s = CONCAT(&#39;ALTER TABLE &#39;,tablenamein,&#39; ADD PARTITION (PARTITION &#39;,maxMonitTimeStr,&#39; VALUES LESS THAN (/&#39;&#39;,maxMonitTime,&#39;/&#39;) ENGINE = InnoDB )&#39;);

050

/*定义预处理语句*/

051

prepare stmt from @v_add_s;

052

/*执行预处理语句*/

053

execute stmt;

054

/*释放预处理语句*/

055

deallocate prepare stmt;

056

-- 开始在table_fen_qu中添加记录

057

insert into table_fen_qu(fenquname,tablename,monittime,backupflag) VALUES(maxMonitTimeStr,tablenamein,maxMonitTime,0);

058

-- 记录数加1

059

set recoidNum = recoidNum + 1;

060

end while;

061

end if;

062

else

063

set recoidNum = 1;

064

-- 计算最小时间

065

set minMOnitTimeStr= CONCAT(DATE_FORMAT(DATE_SUB(maxMonitTime,INTERVAL 60 DAY),&#39;%Y-%m-%d&#39;),&#39; 00:00:00&#39;);

066

set minMOnitTime= STR_TO_DATE(minMonitTimeStr,&#39;%Y-%m-%d %H:%i:%s&#39;);

067

-- 计算最大时间

068

set maxMOnitTimeStr= CONCAT(DATE_FORMAT(ADDDATE(maxMonitTime,INTERVAL 4 DAY),&#39;%Y-%m-%d&#39;),&#39; 00:00:00&#39;);

069

set maxMOnitTime= STR_TO_DATE(maxMonitTimeStr,&#39;%Y-%m-%d %H:%i:%s&#39;);

070

-- 计算新建表分区个数

071

set newIntervalNum = floor(timestampdiff(hour,minMonitTime,maxMonitTime) / intervalHour) + 1;

072

if newIntervalNum <10 then

073

set newIntervalNum = 10;

074

end if;

075

-- 删除所有表分区

076

set @v_del_s = CONCAT(&#39;ALTER TABLE &#39;,tablenamein,&#39; remove partitioning&#39;);

077

/*定义预处理语句*/

078

prepare stmt from @v_del_s;

079

/*执行预处理语句*/

080

execute stmt;

081

/*释放预处理语句*/

082

deallocate prepare stmt;

083

-- 删除所有数据

084

delete from table_fen_qu where tablename= tablenamein;

085

-- 新建分区

086

while recoidNum <= newIntervalNum do

087

set minMOnitTimeStr= CONCAT(&#39;p&#39;,DATE_FORMAT(minMonitTime,"%Y%m%d%H%i%s"));

088

-- 开始添加分区表

089

/*拼接分区表代码段*/

090

if recoidNum = 1 then

091

set @v_add_s = CONCAT(&#39;ALTER TABLE &#39;,tablenamein,&#39; PARTITION BY RANGE COLUMNS(moint_time) (PARTITION &#39;,minMonitTimeStr,&#39; VALUES LESS THAN (/&#39;&#39;,minMonitTime,&#39;/&#39;) ENGINE = InnoDB )&#39;);

092

else

093

set @v_add_s = CONCAT(&#39;ALTER TABLE &#39;,tablenamein,&#39; ADD PARTITION (PARTITION &#39;,minMonitTimeStr,&#39; VALUES LESS THAN (/&#39;&#39;,minMonitTime,&#39;/&#39;) ENGINE = InnoDB )&#39;);

094

end if;

095

/*定义预处理语句*/

096

prepare stmt from @v_add_s;

097

/*执行预处理语句*/

098

execute stmt;

099

/*释放预处理语句*/

100

deallocate prepare stmt;

101

-- 开始在table_fen_qu中添加记录

102

insert into table_fen_qu(fenquname,tablename,monittime,backupflag) VALUES(minMonitTimeStr,tablenamein,minMonitTime,0);

103

-- 记录数加1

104

set recoidNum = recoidNum + 1;

105

set minMOnitTime= ADDDATE(minMonitTime,INTERVAL intervalHour HOUR);

106

end while;

107

end if;

108

end general_pro;

删除分区表的存储过程如下:

01

drop procedure if exists del_fenqu;

02

-- 删除&#39;temp_data&#39;,&#39;no_energy_five_minute_data&#39;,&#39;energy_five_minute_data&#39;及&#39;energy_five_minute_data_summarize&#39;共4个表中已备份的分区表

03

create procedure del_fenqu()

04

del_fq:begin

05

-- 参数:记录id

06

declare myrecid int;

07

-- 参数:分区表名称

08

declare myfenquname varchar(50);

09

-- 参数:表分区所在表的表名称

10

declare mytablename varchar(50);

11

-- 参数:数据库记录数

12

declare recoidNum int default 0;

13

-- 在该表中,查询符合条件的记录数,backupflag=1说明是已备份

14

select count(*) into recoidNum from table_fen_qu where tablename in (&#39;temp_data&#39;,&#39;no_energy_five_minute_data&#39;,&#39;energy_five_minute_data&#39;,&#39;energy_five_minute_data_summarize&#39;) and backupflag=1;

15

-- 存在符合条件的记录则全部删除

16

while recoidNum > 0 do

17

-- 查询出一条

18

select recid,fenquname,tablename into myrecid,myfenquname,mytablename from table_fen_qu where tablename in (&#39;temp_data&#39;,&#39;no_energy_five_minute_data&#39;,&#39;energy_five_minute_data&#39;,&#39;energy_five_minute_data_summarize&#39;) and backupflag=1 order by monittime desc limit 1;

19

-- 删除数据记录

20

delete from table_fen_qu WHERE recid = myrecid;

21

-- 删除表分区

22

/*拼接分区表代码段*/

23

set @v_drop_d=CONCAT(&#39;ALTER TABLE &#39;,mytablename,&#39; DROP PARTITION &#39;,myfenquname);

24

/*定义预处理语句*/

25

prepare stmt from @v_drop_d;

26

/*执行预处理语句*/

27

execute stmt;

28

/*释放预处理语句*/

29

deallocate prepare stmt;

30

-- 在该表中,查询符合条件的记录数,backupflag=1说明是已备份

31

select count(*) into recoidNum from table_fen_qu where tablename in (&#39;temp_data&#39;,&#39;no_energy_five_minute_data&#39;,&#39;energy_five_minute_data&#39;,&#39;energy_five_minute_data_summarize&#39;) and backupflag=1;

32

end while;

33

end del_fq;

第二步:建立事件计划,定时执行事件。

事件如下:

01

-- 打开事件计划

02

SET GLOBAL event_scheduler = ON;

03

/*创建从开始时间每隔1天定时执行*/

04

drop event if exists eachDayEvent;

05

DELIMITER ||

06

create event eachDayEvent

07

on schedule every 1 day starts &#39;2013-05-01 00:00:00&#39;

08

on completion preserve enable

09

do

10

begin

11

-- general_procedure的参数:表名,分区表之间的时间间隔(单位为小时),要新增的分区表个数

12

-- 非能耗5分钟表-间隔6小时-6h/分区表

13

call general_procedure(&#39;no_energy_five_minute_data&#39;,6,8);

14

-- 原始数据表-间隔6小时-6h/分区表

15

call general_procedure(&#39;temp_data&#39;,6,8);

16

-- 能耗五分钟-间隔天-24h/分区表

17

call general_procedure(&#39;energy_five_minute_data&#39;,24,4);

18

-- 能耗五分钟汇总-间隔天-24h/分区表

19

call general_procedure(&#39;energy_five_minute_data_summarize&#39;,24,4);

20

-- 能耗小时表调用-间隔周-7*24h/分区表

21

call general_procedure(&#39;energy_hour_data_summarize&#39;,168,4);

22

-- 能耗分类分项5分钟表-间隔周7*24h/分区表

23

call general_procedure(&#39;energy_item_five_minute_data&#39;,168,4);

24

-- 能耗分类分项小时表-间隔季度-90*24h/分区表

25

call general_procedure(&#39;energy_item_hour_data&#39;,2160,4);

26

-- 能耗天汇总表-间隔半年-4380h/分区表

27

call general_procedure(&#39;energy_day_data_summarize&#39;,4380,4);

28

-- 删除已备份的分区表

29

call del_fenqu();

30

end ||

31

DELIMITER ;

32

bitsCN.com
推荐阅读
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • 本文由编程笔记小编整理,介绍了PHP中的MySQL函数库及其常用函数,包括mysql_connect、mysql_error、mysql_select_db、mysql_query、mysql_affected_row、mysql_close等。希望对读者有一定的参考价值。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • 数据库(外键及其约束理解)(https:www.cnblogs.comchenxiaoheip6909318.html)My ... [详细]
  • 本文介绍了高校天文共享平台的开发过程中的思考和规划。该平台旨在为高校学生提供天象预报、科普知识、观测活动、图片分享等功能。文章分析了项目的技术栈选择、网站前端布局、业务流程、数据库结构等方面,并总结了项目存在的问题,如前后端未分离、代码混乱等。作者表示希望通过记录和规划,能够理清思路,进一步完善该平台。 ... [详细]
  • 本文介绍了在Mac上搭建php环境后无法使用localhost连接mysql的问题,并通过将localhost替换为127.0.0.1或本机IP解决了该问题。文章解释了localhost和127.0.0.1的区别,指出了使用socket方式连接导致连接失败的原因。此外,还提供了相关链接供读者深入了解。 ... [详细]
  • yum安装_Redis —yum安装全过程
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了Redis—yum安装全过程相关的知识,希望对你有一定的参考价值。访问https://redi ... [详细]
  • 解决VS写C#项目导入MySQL数据源报错“You have a usable connection already”问题的正确方法
    本文介绍了在VS写C#项目导入MySQL数据源时出现报错“You have a usable connection already”的问题,并给出了正确的解决方法。详细描述了问题的出现情况和报错信息,并提供了解决该问题的步骤和注意事项。 ... [详细]
  • 本文介绍了关于apache、phpmyadmin、mysql、php、emacs、path等知识点,以及如何搭建php环境。文章提供了详细的安装步骤和所需软件列表,希望能帮助读者解决与LAMP相关的技术问题。 ... [详细]
  • 本文介绍了通过mysql命令查看mysql的安装路径的方法,提供了相应的sql语句,并希望对读者有参考价值。 ... [详细]
  • 本文详细介绍了MySQL表分区的创建、增加和删除方法,包括查看分区数据量和全库数据量的方法。欢迎大家阅读并给予点评。 ... [详细]
  • 本文介绍了如何使用C#制作Java+Mysql+Tomcat环境安装程序,实现一键式安装。通过将JDK、Mysql、Tomcat三者制作成一个安装包,解决了客户在安装软件时的复杂配置和繁琐问题,便于管理软件版本和系统集成。具体步骤包括配置JDK环境变量和安装Mysql服务,其中使用了MySQL Server 5.5社区版和my.ini文件。安装方法为通过命令行将目录转到mysql的bin目录下,执行mysqld --install MySQL5命令。 ... [详细]
  • mysql-cluster集群sql节点高可用keepalived的故障处理过程
    本文描述了mysql-cluster集群sql节点高可用keepalived的故障处理过程,包括故障发生时间、故障描述、故障分析等内容。根据keepalived的日志分析,发现bogus VRRP packet received on eth0 !!!等错误信息,进而导致vip地址失效,使得mysql-cluster的api无法访问。针对这个问题,本文提供了相应的解决方案。 ... [详细]
  • 众筹商城与传统商城的区别及php众筹网站的程序源码
    本文介绍了众筹商城与传统商城的区别,包括所售产品和玩法不同以及运营方式不同。同时还提到了php众筹网站的程序源码和方维众筹的安装和环境问题。 ... [详细]
author-avatar
mobiledu2502916503
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有