MySQL分区表如何实现按月份归类
发表于:2025-02-06 作者:千家信息网编辑
千家信息网最后更新 2025年02月06日,小编给大家分享一下MySQL分区表如何实现按月份归类,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!建表一般的表(innod
千家信息网最后更新 2025年02月06日MySQL分区表如何实现按月份归类建表
查看数据库文件:
插入
查询
删除
小编给大家分享一下MySQL分区表如何实现按月份归类,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
建表
一般的表(innodb)创建后只有一个 idb 文件:
create table normal_table(id int primary key, no int)
查看数据库文件:
normal_table.ibd
创建按月份分区的分区表,注意!除了常规主键外,月份字段(用来分区的字段)也必须是主键:
create table partition_table(id int AUTO_INCREMENT, create_date date, name varchar(10), primary key(id, create_date)) ENGINE=INNODB DEFAULT CHARSET=utf8 partition by range(month(create_date))(partition quarter1 values less than(4),partition quarter2 values less than(7),partition quarter3 values less than(10),partition quarter4 values less than(13));
查看数据库文件:
partition_table#p#quarter1.ibd partition_table#p#quarter2.ibd partition_table#p#quarter3.ibd partition_table#p#quarter4.ibd
插入
insert into partition_table(create_date, name) values("2021-01-25", "tom1");insert into partition_table(create_date, name) values("2021-02-25", "tom2");insert into partition_table(create_date, name) values("2021-03-25", "tom3");insert into partition_table(create_date, name) values("2021-04-25", "tom4");insert into partition_table(create_date, name) values("2021-05-25", "tom5");insert into partition_table(create_date, name) values("2021-06-25", "tom6");insert into partition_table(create_date, name) values("2021-07-25", "tom7");insert into partition_table(create_date, name) values("2021-08-25", "tom8");insert into partition_table(create_date, name) values("2021-09-25", "tom9");insert into partition_table(create_date, name) values("2021-10-25", "tom10");insert into partition_table(create_date, name) values("2021-11-25", "tom11");insert into partition_table(create_date, name) values("2021-12-25", "tom12");
查询
select count(*) from partition_table;> 12 查询第二个分区(第二季度)的数据:select * from partition_table PARTITION(quarter2);4 2021-04-25 tom45 2021-05-25 tom56 2021-06-25 tom6
删除
当删除表时,该表的所有分区文件都会被删除
补充:Mysql自动按月表分区
核心的两个存储过程:
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 PRESERVEENABLEDOBEGINcall 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后重启即可。
以上是"MySQL分区表如何实现按月份归类"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
数据
月份
文件
分区表
字段
篇文章
归类
内容
数据库
过程
错误
会报
存储
查询
不怎么
两个
事项
二季度
功能
历史
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
服务器加硬盘后识别不了
天跃软件开发有限公司
山东农产品供应链服务软件开发商
服务器批量部署
迅广网络技术有限公司电话
数据库管理技术独立性
关于加强网络安全防范工作
过去常用数据库
咸阳网络安全工作会议
数据库表的本质
数据库命名冲突与结构冲突
创新创业课程问答数据库
崇明区机电软件开发厂家直销
百度地图如何自定义服务器
组织网络安全企业展
数据库数据字符过长
微信小程序和数据库交互案例
光明区光纤网络技术开发展示
obs推流服务器是什么
数据库 数据中心
公司内部dns服务器
换服务器以后插件怎么改
公安网络安全专项行动
怎么在数据库中删除一个流程
北京友联众科网络技术有限公司
本地浏览器访问不到服务器
优悦网络技术有限公司
为什么收到网络安全自查整改
网络技术和计算机通信区别
软件开发标准化流程