mysql 分区PARTITIONS之基本使用当数据表中的数据量很大时 , 分区带来的效率提升才会显现出来 。
只有检索字段为分区字段时,分区带来的效率提升才会比较明显 。因此,分区字段的选择很重要 ,并且 业务逻辑要尽可能地根据分区字段做相应调整 (尽量使用分区字段作为查询条件) 。
1、分区表对业务透明,只需要维护一个表的数据结构 。
2、DML操作加锁仅影响操作的分区,不会影响未访问分区 。
3、通过分区交换快速将数据换入和换出分区表 。
【mysql中分区怎么删 mysql删除分区数据】4、通过TRUNCATE操作快速清理特定分区数据 。
5、通过强制分区仅访问特定分区数据,减少操作影响 。
6、通过大数据量分区能有效降低索引层数 , 提高查询性能 。
1、创建表时指定分区
物理文件:
2、插入数据
3、查询information_schema.partitions表得到该表的分区信息
4、查询计划分析
5、添加分区
若报错:
6、修改/覆盖/合并分区
报错
所以需要添加pmax 分区 , 一同修改
7、删除分区
8、查询具体分区的下数据
MySQL分区的限制
怎么循环创建mysql表分区和清空表分区怎么循环创建mysql表分区和清空表分区
如果是mysql5.5还是可以做到的,5.1不行
CREATE TABLE part_date
( c1 bigint(20) unsigned NOT NULL AUTO_INCREMENT,
c2 varchar(40) not null default '',
c3 datetime not NULL,
PRIMARY KEY (c1,c3),
KEY partidx(c3)) ENGINE=InnoDB DEFAULT CHARSET=utf8
partition by range COLUMNS(c3)
(
PARTITION p201012 VALUES LESS THAN ('2011-01-01 06:00:00'),
PARTITION p201101 VALUES LESS THAN ('2011-01-01 12:00:00'),
PARTITION p201102 VALUES LESS THAN ('2011-01-01 18:00:00'),
PARTITION p201103 VALUES LESS THAN ('2011-01-01 23:59:59'),
PARTITION p201912 VALUES LESS THAN MAXVALUE );
然后用函数录入数据
DELIMITER $$
DROP PROCEDURE IF EXISTS `load_data` $$
CREATE DEFINER=`root`@`%` PROCEDURE `load_data`()
BEGIN
declare v int default 0;
while v10000
do
insert into part_date(c2,c3)
values (uuid(),'2011-01-01 01:00:00');
insert into part_date(c2,c3)
values (uuid(),'2011-01-01 03:00:00');
insert into part_date(c2,c3)
values (uuid(),'2011-01-01 05:01:00');
insert into part_date(c2,c3)
values (uuid(),'2011-01-01 07:01:00');
insert into part_date(c2,c3)
values (uuid(),'2011-01-01 15:01:00');
insert into part_date(c2,c3)
values (uuid(),'2011-01-01 16:01:00');
insert into part_date(c2,c3)
values (uuid(),'2011-01-01 17:01:00');
insert into part_date(c2,c3)
values (uuid(),'2011-01-01 18:01:00');
insert into part_date(c2,c3)
values (uuid(),'2011-01-01 19:01:00');
set v = v + 1;
end while;
END $$
DELIMITER ;
分区
explain partitions select count(*) from part_date where c3date '2011-01-01 06:02:00' and c3date '2011-01-01 08:02:00'
看一下只走了p201101分区
十、MySQL表分区 ??表分区是将?个表的数据按照?定的规则?平划分为不同的逻辑块,并分别进?物理存储,这个规则就叫做分区函数,可以有不同的分区规则 。5.7可以通过show plugins语句查看当前MySQL是否?持表分区功能 。
??但当表中含有主键或唯?键时,则每个被?作分区函数的字段必须是表中唯?键和主键的全部或?部分,否则就?法创建分区表 。?如下?的表由于唯?键和主键没有相同的字段,所以?法创建表分区
上述例?中删除唯?键,确保主键中的字段包含分区函数中的所有字段,创建成功
或者将主键扩展为包含ref字段
推荐阅读
- 温婉直播设备文案,主播直播文案
- python获取下月时间,python获取当前年月日
- 直播甜蜜文案素材,直播文案短句
- Go语言编程之旅pdf go语言编程之旅一起用go做项目
- 微信小程序开发管理已禁用,微信小程序开发管理在哪里
- 装修经营游戏苹果,ios装修游戏
- saperp集成,erp的集成范围
- php实时更新数据场景 php更新数据库字段
- 虚拟机创建字典的方法,虚拟机创建字典的方法是什么