墨斋记

Good Luck To You!

MySQL优化分表

1. 基本概念

基本概念:把一个表,从逻辑上分成多个区域,便于存储数据。

采用分区的前提:数据量非常大。

比如一个用户表,想分成4个区域,如何分呢?

用户的id 1到1000 分到 东区
用户的id 1001到2000 分到 南区
用户的id 2001到3000 分到 西区
用户的id 大于3001的 分到 北区

2. 创建语法

create table user (    // 创建表的语句
)engine myisam charset utf8
partition by 分区类型 (分区的关键字) (    // 分区的项
);

3. 分区的类型

(1)list:条件值为一个数据列表。

通过预定义的列表的值来对数据进行分割

例子:假如你创建一个如下的一个表,该表保存有全国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

复制代码
create table p_list( 
    id int, 
    name varchar(32), 
    store_id int )partition by list (store_id)( 
    partition p_north values in(1,4,5,6,17,18), 
    partition p_east values in(2,7,9,10,11,13), 
    partition p_south values in(3,12,19,20), 
    partition p_west values in(8,14,15,16) 
);
复制代码

测试是否用到了分区:

explain partitions select * from p_list where store_id=20\G

注意:在使用分区时,where后面的字段必须是分区字段,才能使用到分区。

(2)Range(范围)

这种模式允许将数据划分不同范围。例如可以将一个表通过年份划分成若干个分区

复制代码
create table p_range(
    id int,
    name varchar(32),
    birthday date
)partition by range (month(birthday))(
    partition p_1 values less than (3),
    partition p_2 values less than(6),
    partition p_3 values less than(9),
    partition p_4 values less than MAXVALUE
);
复制代码

less than 小于等于
MAXVALUE 可能的最大值

4. 分区表的限制

只能对数据表的整型列进行分区,或者数据列可以通过分区函数转化成整型列,最大分区数目不能超过1024。

如果含有唯一索引或者主键,则分区列必须包含在所有的唯一索引或者主键在内。

不支持外键

不支持全文索引(fulltext)

按日期进行分区很非常适合,因为很多日期函数可以用。但是对于字符串来说合适的分区函数不太多。

 


发表评论:

Powered By Z-BlogPHP 1.7.3

冀公网安备13019902000834
冀ICP备18019600号-1
Copyright CC Some Rights Reserved.Contact Email:chengyingbo88@163.com