MySql表分区(根据时间datetime)

timestamp 类型分区请移步=>MySql表分区(根据时间timestamp)
环境:
  MySql8.0.18(5.6和5.7的未验证)
  分区条件的字段类型是datetime
完整的sql操作表分区的语句如下:

-- 1.删除表
drop table t_test;

-- ===================================================================================
-- 2.创建一个表并对其分区,被创建分区的字段必须为主键,或者创建分区时表中没有主键
-- 2.1 方式一:表和分区一起创建
create table t_test (
        id int,
        dates timestamp
)partition by range (unix_timestamp(dates)) (
        -- 小于2018-01-01的
        partition p1 values less than (unix_timestamp(‘2018-01-01‘)),
        partition p2 values less than (unix_timestamp(‘2018-02-01‘)),
        partition p3 values less than (unix_timestamp(‘2018-03-01‘)),
        -- 大于2018-03-01的
        partition p4 values less than maxvalue
);

-- ===================================================================================
-- 2.2 方式二:表和分区分开创建
-- 2.2.1 建表
create table `t_test`  (
  `id` int(11) not null,
  `dates` datetime(0) not null on update current_timestamp(0),
  primary key (`id`, `dates`)
);

-- 3. 修改分区信息
alter table t_test partition by range (to_days(dates)) (
    -- 小于2020-01-01的
    partition p1 values less than (to_days(‘2020-01-01‘)),
    partition p2 values less than (to_days(‘2020-02-01‘)),
    partition p3 values less than (to_days(‘2020-03-01‘)),
    partition p4 values less than (to_days(‘2020-04-01‘)),
    -- 大于2020-04-01的
    partition p5 values less than maxvalue
);

-- ===================================================================================
-- 4. 删除并添加新的分区(注意:如果原先最后一个分区是partition pnow values less than maxvalue; 那么应该先删除该分区,然后在执行新增分区语句,然后再新增回该分区)
-- 4.1 删除一个分区(注意:删除一个分区时,该分区内的所有数据也都会被删除;)
alter table t_test drop partition p5;
-- 4.2 新增一个分区
alter table t_test add partition (partition p6 values less than (to_days(‘2020-05-01‘)));
-- 4.3 新增一个分区(不满足其余分区条件的都存放在这个分区)
alter table t_test add partition (partition p7 values less than maxvalue);

-- ===================================================================================
-- 5.查询这个表有多少分区
-- 5.1查询每一个分区对应的数量
select
    partition_name part, partition_expression expr, partition_description descr,
    from_days(partition_description) expirydate, table_rows
from
    information_schema.`partitions`
where
    table_name=‘t_test‘; 

-- 6.创建测试数据
-- 小于2020-01-01 2条
insert into `t_test` values (‘1‘, ‘2018-01-02 15:00:00‘);
insert into `t_test` values (‘2‘, ‘2019-12-02 15:00:00‘);
-- 2020-01-01至2020-02-01 1条
insert into `t_test` values (‘3‘, ‘2020-01-02 16:00:00‘);
-- 2020-02-01至2020-03-01 2条
insert into `t_test` values (‘4‘, ‘2020-02-03 15:00:00‘);
insert into `t_test` values (‘5‘, ‘2020-02-03 15:00:00‘);
-- 2020-03-01至2020-04-01 1条
insert into `t_test` values (‘6‘, ‘2020-03-03 15:00:00‘);
-- 2020-04-01至2020-05-01 1条
insert into `t_test` values (‘7‘, ‘2020-04-03 15:00:00‘);
-- 大于2020-05-01 4条
insert into `t_test` values (‘8‘, ‘2020-05-03 15:00:00‘);
insert into `t_test` values (‘8‘, ‘2020-06-03 15:00:00‘);
insert into `t_test` values (‘8‘, ‘2020-06-06 15:00:00‘);
insert into `t_test` values (‘8‘, ‘2021-01-01 15:00:00‘);

-- 6.查询数据
select * from t_test;

我们使用第5步的sql可以查看分区信息
  可以看到2020-01-01之前的有2条信息,2020-01-01至2020-02-01之前的有1条信息,以此类推,最后2020-05-01之后的一共有4条信息

也可使用Navicat for MySQL工具操作分区:Navicat for MySQL进行表分区操作(图解)
timestamp 类型分区请移步=>MySql表分区(根据时间timestamp)

原文地址:https://blog.51cto.com/1197822/2456558

时间: 2024-10-20 09:27:01

MySql表分区(根据时间datetime)的相关文章

查看Mysql表分区语句

SELECT partition_name part, partition_expression expr, partition_description descr, table_rows FROM INFORMATION_SCHEMA.partitions WHERE TABLE_SCHEMA = schema() AND TABLE_NAME='table'; 查看Mysql表分区语句

Mysql 表分区和性能

以下内容节选自<Mysql技术内幕InnoDB存储引擎> mysql表分区: 分区功能并不是所有存储引擎都支持的,如CSV.MERGE等就不支持.mysql数据库支持的分区类型为水平分区(指一张表中不同行的记录分配到不同的物理文件中),不支持垂直分区(指将同一表中的不同列分配到不同的物理文件中).此外,mysql数据库的分区是局部分区索引,一个分区中既存放了数据又存放了索引. 当前Mysql数据库支持以下几种类型的分区: Range分区:行数据基于一个给定连续区间的列值放入分区.Mysql数据

mysql 表分区技术

表分区,是指根据一定规则,将数据库中的一张表分解成多个更小的,容易管理的部分.从逻辑上看,只有一张表,但是底层却是由多个物理分区组成. 表分区有什么好处: a.分区表的数据可以分布在不同的物理设备上,从而高效地利用多个硬件设备. b.和单个磁盘或者文件系统相比,可以存储更多数据 c.优化查询.在where语句中包含分区条件时,可以只扫描一个或多个分区表来提高查询效率:涉及sum和count语句时,也可以在多个分区上并行处理,最后汇总结果.d.分区表更容易维护.例如:想批量删除大量数据可以清除整个

mysql表分区(摘自 MySQL表的四种分区类型)

一.什么是表分区通俗地讲表分区是将一大表,根据条件分割成若干个小表.mysql5.1开始支持数据表分区了. 如:某用户表的记录超过了600万条,那么就可以根据入库日期将表分区,也可以根据所在地将表分区.当然也可根据其他的条件分区. 二.为什么要对表进行分区为了改善大型表以及具有各种访问模式的表的可伸缩性,可管理性和提高数据库效率. 分区的一些优点包括: 与单个磁盘或文件系统分区相比,可以存储更多的数据.对于那些已经失去保存意义的数据,通常可以通过删除与那些数据有关的分区,很容易地删除那些数据.相

MySQL 表分区详解

一.什么是表分区通俗地讲表分区是将一大表,根据条件分割成若干个小表.mysql5.1开始支持数据表分区了.如:某用户表的记录超过了1000万条,那么就可以根据入库日期将表分区,也可以根据所在地将表分区.当然也可根据其他的条件分区. 二.为什么要对表进行分区为了改善大型表以及具有各种访问模式的表的可伸缩性,可管理性和提高数据库效率.分区的一些优点包括:      1).与单个磁盘或文件系统分区相比,可以存储更多的数据.      2).对于那些已经失去保存意义的数据,通常可以通过删除与那些数据有关

Mysql表分区几种方式

自5.1开始对分区(Partition)有支持,一张表最多1024个分区 查询分区数据: SELECT * from table PARTITION(p0) = 水平分区(根据列属性按行分)= 举个简单例子:一个包含十年发票记录的表可以被分区为十个不同的分区,每个分区包含的是其中一年的记录. === 水平分区的几种模式:=== * Range(范围) – 这种模式允许DBA将数据划分不同范围.例如DBA可以将一个表通过年份划分成三个分区,80年代(1980's)的数据,90年代(1990's)的

Mysql 表分区

创建分区表: DELIMITER // create table VMMoniterData ( id_ bigint not null AUTO_INCREMENT, vmid varchar(75) null, cpu varchar(75) null, memory varchar(75) null, bpsRead varchar(75) null, bpsWrite varchar(75) null, intranetRX0 varchar(75) null, intranetRX1

mysql表分区、查看分区

原文地址:http://blog.csdn.net/feihong247/article/details/7885199 一.       mysql分区简介 数据库分区 数据库分区是一种物理数据库设计技术.虽然分区技术可以实现很多效果,但其主要目的是为了在特定的SQL操作中减少数据读写的总量以缩减sql语句的响应时间,同时对于应用来说分区完全是透明的. MYSQL的分区主要有两种形式:水平分区和垂直分区 水平分区(HorizontalPartitioning) 这种形式的分区是对根据表的行进行

MYSQL 表分区的 3 方法

背景知识: 表分区是把逻辑上同一范围的数据保存到同一个文件中,就和超市一样,把同类商品放在同一个区域,把不同的商品放在不同的地方.不同的是超市中 是根据用途分类的,表分区是根据它的取值区间来分的. 分区有什么用? 1.分区后可以用多个文件来保存表中的数据,而这几个文件可以位于不同的硬盘上,这样就可以同时利用多个硬盘的IO能力. 2.分区后锁就会更灵活,如果一次要锁定大量的数据行,而表没有分区,MYSQL 可能会为了减小在锁上的开销,会把行锁升 级为表锁,如果表分区了,要访问的数据行只在表的一两个