视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
mysql建立分区的两种方式介绍(代码示例)
2020-11-09 08:39:41 责编:小采
文档


本篇文章给大家带来的内容是关于mysql 建立分区的两种方式介绍(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

#list分区--键值通过自定义的list来确定写入到哪个分区中。

优势:支持int,时间,varchar等值

劣势:需要自己写相应数据的从属(写入或者查询到哪个分区),即后期若分区条件修改需要再配置。

CREATE TABLE t_test (
 unid INT auto_increment , 
 uuid VARCHAR(36),
 cdate datetime,
 type int,
 text varchar(30),
 PRIMARY KEY(unid,type)
)
PARTITION BY LIST COLUMNS(type) ( #这里以type字段来分区,list分区中,这个字段可以为int整形或者某个值
 PARTITION pRegion_1 VALUES IN (1), #这里的意思是,当type=1时,数据会写入到pRegion_1分区中
 PARTITION pRegion_2 VALUES IN (2), #同上
 PARTITION pRegion_3 VALUES IN (3),
 PARTITION pRegion_4 VALUES IN (4)
);

#hash分区--键值通过hash算法计算后,自动写入到相应的分区中 。

优势:不需要自己写相应数据的从属(写入或者查询到哪个分区)

劣势:只支持int整型

CREATE TABLE t_test (
 unid INT auto_increment ,
 uuid VARCHAR(36),
 cdate datetime,
 type int,
 text varchar(30),
 PRIMARY KEY(unid,type) #复合主键,因为后面要用type字段来分区
)
PARTITION BY HASH ( type ) #这里以type字段来分区,type必须是主键或者是复合主键包含的字段,hash分区的方式必须该字段为int
PARTITIONS 10; #这里设定的是分区数为10,数据会通过type字段经过hash算法后,自动归属到10个分区中的某个分区中

下载本文
显示全文
专题