iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >MySQL分区表如何实现按月份归类
  • 665
分享到

MySQL分区表如何实现按月份归类

2023-06-25 11:06:16 665人浏览 薄情痞子
摘要

小编给大家分享一下MySQL分区表如何实现按月份归类,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!建表一般的表(innodb)创建后只有一个 idb 文件:cre

小编给大家分享一下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分区表如何实现按月份归类”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网数据库频道!

您可能感兴趣的文档:

--结束END--

本文标题: MySQL分区表如何实现按月份归类

本文链接: https://www.lsjlt.com/news/304348.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL分区表如何实现按月份归类
    小编给大家分享一下MySQL分区表如何实现按月份归类,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!建表一般的表(innodb)创建后只有一个 idb 文件:cre...
    99+
    2023-06-25
  • MySQL分区表实现按月份归类
    目录建表 查看数据库文件: 插入 查询 删除 补充:Mysql自动按月表分区MySQL单表数据量,建议不要超过2000W行,否则会对性能有较大影响。最近接手了一个项目,单表数据超70...
    99+
    2024-04-02
  • mysql如何实现按表备份脚本
    这篇文章主要为大家展示了“mysql如何实现按表备份脚本”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“mysql如何实现按表备份脚本”这篇文章吧。 ...
    99+
    2024-04-02
  • 数据库中如何将按月分区的表改为按天分区
    这篇文章给大家分享的是有关数据库中如何将按月分区的表改为按天分区的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 一般来说,按月分区的表都是range分区,下面来介绍将按月分区改...
    99+
    2024-04-02
  • springboot按月分表的实现方式
    目录一、项目背景1、分表的方式二、代码实现1、pom文件依赖2、配置文件3、MybatisPlusConfig实现4、优雅的使用5、mysql表名拆分三、遇到的问题1、Invalid...
    99+
    2023-05-16
    springboot 按月分表 springboot 分表
  • Java如何将时间按月份分段
    本篇内容介绍了“Java如何将时间按月份分段”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!前言有时候我们得到一段时间,需要将时间按照月份将这...
    99+
    2023-06-20
  • mysql按照今年的每个月的月份分组,月份没数据的补0,(查询虚拟时间表)
    需求:统计今年的每个月的设备故障数,如果那个月没有需要补0。 比如,当前是7月,那就统计1月到7月的数据,如果当前是1月,那就统计1月的,如果是11月,那就统计1月到11月的。 直接对表分组的话,如果5月没有数据,是没有5月这个结果的,所以...
    99+
    2023-08-30
    mysql
  • 如何在MySQL中实现分表和分区
    如何在MySQL中实现分表和分区?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。垂直分表垂直分表就是一个包含有很多列的表拆分成多...
    99+
    2024-04-02
  • MySQL如何实现清空分区表单个分区数据
    这篇“MySQL如何实现清空分区表单个分区数据”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“MySQL如何实现清空分区表单个...
    99+
    2023-07-05
  • Java将时间按月份分段的实现思路与方法
    前言 有时候我们得到一段时间,需要将时间按照月份将这一段时间来分段。比如开始时间为 2020/07/15 至 2021/07/05 按照月份来将数据分组展示,所以需要将这端时间分为...
    99+
    2024-04-02
  • 数据库中如何自动创建分区函数并按月分区
    小编给大家分享一下数据库中如何自动创建分区函数并按月分区,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧! declare  @tableName va...
    99+
    2024-04-02
  • 如何实现mysql的分库备份
    这篇文章主要讲解了“如何实现mysql的分库备份”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何实现mysql的分库备份”吧! 分库备份实际上就是执行一...
    99+
    2024-04-02
  • Hive中如何实现分区表
    这篇文章主要为大家展示了“Hive中如何实现分区表”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Hive中如何实现分区表”这篇文章吧。分区表对于一张比较大的表,将其设计成分区表可以提升查询的性能...
    99+
    2023-06-02
  • mysql分库分表如何实现
    MySQL分库分表可以通过以下几个步骤实现: 水平分库:将原始的单个数据库分成多个独立的数据库。每个数据库可以独立运行在不同的服务...
    99+
    2023-10-27
    mysql
  • MySQL中怎么实现分区表
    MySQL中怎么实现分区表,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。   MySQL分区的建立 MySQL可以建立四种分区...
    99+
    2024-04-02
  • MySQL中如何实现分库分表
    本篇文章为大家展示了MySQL中如何实现分库分表,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。一、    背景介绍1.大数据...
    99+
    2024-04-02
  • MySQL实现清空分区表单个分区数据
    目录mysql清空分区表单个分区数据1.单个分区清空2.编辑存储过程MySQL自动分区自动清理完整的SQL查看分区总结MySQL清空分区表单个分区数据 1.单个分区清空 ALTER TABLE xxx TRUN...
    99+
    2023-03-13
    MySQL清空分区表 MySQL分区数据 MySQL分区表
  • mysql如何创建分区表
    MySQL可以通过以下步骤来创建分区表:1. 创建一个普通的表,定义它的列和其他属性。2. 使用`ALTER TABLE`语句来添加...
    99+
    2023-10-12
    mysql
  • 如何使用MySQL分区表
    这篇文章给大家介绍如何使用MySQL分区表,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。分区是一种表的设计模式,通俗地讲表分区是将一大表,根据条件分割成若干个小表。但是对于应用程序来讲...
    99+
    2024-04-02
  • mysql如何实现水平分表
    mysql如何实现水平分表?这个问题可能是我们日常学习或工作经常见到的。希望通过这个问题能让你收获颇深。下面是小编给大家带来的参考内容,让我们一起来看看吧!Mysql表数据一般达到百万级别,查询效率会很低,...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作