编程知识 cdmana.com

mysql的分区跟分表

mysql的分区和分表

分区

分区就是把一个数据表的文件和索引分散存储在不同的物理文件中。

 


 

mysql支持的分区类型包括Range、List、Hash、Key,其中Range比较常用:

RANGE分区:基于属于一个给定连续区间的列值,把多行分配给分区。

LIST分区:类似于按RANGE分区,区别在于LIST分区是基于列值匹配一个离散值集合中的某个值来进行选择。

HASH分区:基于用户定义的表达式的返回值来进行选择的分区,该表达式使用将要插入到表中的这些行的列值进行计算。这个函数可以包含MySQL 中有效的、产生非负整数值的任何表达式。

KEY分区:类似于按HASH分区,区别在于KEY分区只支持计算一列或多列,且MySQL服务器提供其自身的哈希函数。必须有一列或多列包含整数值。

 


 

案例:

建立一个user 表 以id进行分区 id 小于10的在user_1分区id小于20的在user_2分区

create table user( id int not null auto_increment, username varchar(10), primary key(id))engine = innodb charset=utf8partition by range (id)(partition user_1 values less than (10),partition user_2 values less than (20));

 

建立后添加分区:

maxvalue 表示最大值   这样大于等于20的id 都出存储在user_3分区

alter table user add partition( partition user_3 values less than maxvalue);

 

 


 

删除分区:

alter table user drop partition user_3;

现在打开mysql的数据目录

可以看见多了user#P#user_1.ibd 和user#P#user_2.ibd  这两个文件

如果表使用的存储引擎是MyISAM类型,就是:

user#P#user_1.MYD,user#P#user_1.MYIuser#P#user_2.MYD,user#P#user_2.MYI

分区模式详解:

* Range(范围) – 这种模式允许DBA将数据划分不同范围。例如DBA可以将一个表通过年份划分成三个分区,80年代(1980's)的数据,90年代(1990's)的数据以及任何在2000年(包括2000年)后的数据。

CREATE TABLE users (   id INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY,   usersname VARCHAR(30) NOT NULL DEFAULT '',   email VARCHAR(30) NOT NULL DEFAULT '' ) PARTITION BY RANGE (id) (   PARTITION p0 VALUES LESS THAN (3000000),   PARTITION p1 VALUES LESS THAN (6000000),  PARTITION p2 VALUES LESS THAN (9000000),   PARTITION p3 VALUES LESS THAN MAXVALUE  );

在这里,将用户表分成4个分区,以每300万条记录为界限,每个分区都有自己独立的数据、索引文件的存放目录。

 


 

还可以将这些分区所在的物理磁盘分开完全独立,可以提高磁盘IO吞吐量。

如果你也想成为程序员,想要快速掌握编程,赶紧关注小编加入学习企鹅圈子吧!

里面有资深专业软件开.........

版权声明
本文为[程序猿欧文]所创,转载请带上原文链接,感谢
https://my.oschina.net/mikeowen/blog/4840710

Scroll to Top