mysql中分区怎么删 mysql删除分区数据( 四 )


解释:分区字段必须是主键之一 。
3、[Err] 1492 - Constant, random or timezone-dependent expressions in (sub)partitioning function are not allowed
解释:分区字段为timestamp , 换成datetime 。
4、[Err] 1526 - Table has no partition for value xxxx
解释:用追加方式第一次必须覆盖目前所有数据 。
总结:
1、创建时必须指定至少一个分区 。
2、key必须为主键之一 。
3、RANGE处必须为INT型,时间字段用函数转——YEAR()、YEARWEEK()、TO_DAYS() 。
4、THAN处必须为INT型,时间字段用函数转——TO_DAYS、TO_SECONDS()、UNIX_TIMESTAMP() 。
5、它就是以两个INT比大小划分的文件 。
6、所有ENGINE必须一样 。
7、范围分区添加只能在最大值后面追加 。
8、分区是有上限的貌似1024个 。
用到的其他操作
1、删除分区(直接扔掉分区文件 , 数据也没了)
ALTER TABLE message_all DROP PARTITION p2016;
2、清空分区数据
ALTER TABLE message_all TRUNCATE PARTITION p2017;
3、重定义(可实现:分区拆分、合并、重命名)
ALTER TABLE message_all REORGANIZE PARTITION p201601,p201602,p201603,p201604 INTO
(
PARTITION p2016012 VALUES less than(TO_DAYS('2016-03-01')),
PARTITION p2016034 VALUES less than(TO_DAYS('2016-05-01'))
);
检查/查看你的分区
1、SHOW TABLE STATUS LIKE 'message_all';
2、SELECT * FROM information_schema.partitions WHERE table_name='message_all';
3、SHOW CREATE TABLE message_all;
4、EXPLAIN SELECT COUNT(1) FROM message_all WHERE createtime= '2016-01-01' AND createtime'2016-12-30';如果用到了分区partitions里会有显示 。
5、指定分区查
SELECT COUNT(1) FROM message_all PARTITION (p2016) 表别名 WHERE ......;
到这里就结束啦,土豆白 。
一些概念
水平分区Partition有以下几种模式
mysql表分区使用及详细介绍一、分区概念
分区是将一个表分成多个区块进行操作和保存 , 从而降低每次操作的数据 , 提高性能 。而对于应用来说则是透明的,从逻辑上看只有一张表 , 但在物理上这个表可能是由多个物理分区组成的,每个分区都是独立的对象 , 可以进行独立处理 。
二、分区作用
1.可以逻辑数据分割 , 分割数据能够有多个不同的物理文件路径 。
2.可以存储更多的数据,突破系统单个文件最大限制 。
3.提升性能 , 提高每个分区的读写速度 , 提高分区范围查询的速度 。
4.可以通过删除相关分区来快速删除数据
5.通过跨多个磁盘来分散数据查询,从而提高磁盘I/O的性能 。
6.涉及到例如SUM()、COUNT()这样聚合函数的查询 , 可以很容易的进行并行处理 。
7.可以备份和恢复独立的分区,这对大数据量很有好处 。
三、分区能支持的引擎
MySQL支持大部分引擎创建分区 , 入MyISAM、InnoDB等;不支持MERGE和CSV等来创建分区 。同一个分区表中的所有分区必须是同一个存储引擎 。值得注意的是,在MySQL8版本中 , MyISAM表引擎不支持分区 。
四、确认MySQL支持分区
从MySQL5.1开始引入分区功能,可以如下方式查看是否支持:
老版本用:SHOW VARIABLES LIKE '%partition%';
新版本用:show plugins;
五、分区类型
1. RANGE分区:基于属于一个给定连续区间的列值,把多行分配给分区 。
例如,可以将一个表通过年份划分成两个分区,2001 -2010年、2011-2020 。
2. LIST分区:类似于RANGE分区,LIST是列值匹配一个离散值集合中的某个值来进行选择 。