把一个表,从逻辑上分成多个区域,便于存储数据。
采用分区的前提,数据量非常大。
如果数据表的记录非常多,比如达到上亿条,数据表的活性就大大降低,数据表的运行速度就比较慢、效率低下,影响mysql数据库的整体性能,就可以采用分区解决
分区是mysql本身就支持的技术
list :条件值为一个数据区。
算法:根据“字段的内容值”是否在某个“区域”中进行分区,通过预定义的列表的值来对数据进行分割。
语法:
利用表选项:partition 完成。
create table table_name(
字段信息,
索引,
) charset utf8
partition by list(分区字段)(
partition list_name1 values in (),
partition list_name2 values in()
);
例子:创建一张表,该表保存有全国20家分公司的职员记录,这20家分公司的编号从1到20.而这20家分公司分布在全国4个区域,如下表所示:
id name store_id(分公司的id)
北部 1,4,5,6,17,18
南部 2,7,9,10,11,13
东部 3,12,19,20
西部 8,14,15,16
查看执行计划
注意:where后面的字段必须是分区字段
定义:利用“字段值”取值范围将数据分区,区间要连续并且不可以重叠,使用VALUES LESS THAN 进行分区定义
less than 小于等于
MAXVALUE 可能的最大值
例子:用户余额表
create table p_range(
id int(11) NOT NULL,
name varchar(32) NOT NULL,
totle_money int(11) NOT NULL
)
partition by range (totle_money)(
partition p1 values less than (100),
partition p2 values less than(1000),
partition p3 values less than(10000),
partition p4 values less than MAXVALUE
);
注意:
1,上面分区语句的VALUES LESS THAN MAXVALUE子句是表示当有大于10000的时候都插入到p4中,MAXVALUE代表最大可能整数值,否则当我们插入一条记录包含10001时会报错。
2,顺序是有规定的,当把p1设为1000而p2设为100时会报错。
3,无论是哪一种分区类型,如果表里有主键,则分区字段必须是主键或者主键的一部分,否则会报错。
A PRIMARY KEY must include all columns in the table‘s partitioning function
如果添加主键 alter table p_range add PRIMARY key(id,totle_money)
给 range/list 增加分区
alter table table_name add partition(
partition 分区名 values less than (常量)
或
partition 分区名 in (n,n,n)
);
给 range/list 删除分区
alter table table_name drop partition 分区名称;
注意:删除的分区里的数据会被删除。
原文:https://www.cnblogs.com/jdbeyond/p/11372681.html