当前位置:Gxlcms > 数据库问题 > mysql分表和表分区详解

mysql分表和表分区详解

时间:2021-07-01 10:21:17 帮助过:2人阅读

Hash(哈希)–这中模式允许通过对表的一个或多个列的Hash Key进行计算,最后通过这个Hash码不同数值对应的数据区域进行分区。例如可以建立一个对表主键进行分区的表。 Key(键值)-上面Hash模式的一种延伸,这里的Hash Key是MySQL系统产生的。 List(预定义列表)–这种模式允许系统通过预定义的列表的值来对数据进行分割。 Composite(复合模式) –以上模式的组合使用 

分表规则与分区规则一样,在分区模块详细介绍。

下面以Range简单介绍下如何分表(按照年份表)。

假设表结构有4个字段:自增id,姓名,存款金额,存款日期

把存款日期作为规则分表,分别创建几个表

2011年:account_2011

2012年:account_2012

……

2015年:account_2015

app在读写的时候根据日期来查找对应的表名,需要手动来判定。

?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 var getTableName = function() {     var data = {         name: ‘tom‘,         money: 2800.00,         date: ‘201410013059‘     };     var tablename = ‘account_‘;     var year = parseInt(data.date.substring(0, 4));     if (year < 2012) {         tablename += 2011; // account_2011     } else if (year < 2013) {         tablename += 2012; // account_2012     } else if (year < 2014) {         tablename += 2013; // account_2013     } else if (year < 2015) {         tablename += 2014; // account_2014     } else {         tablename += 2015; // account_2015     }     return tablename; }

3、利用merge存储引擎来实现分表

merge分表,分为主表和子表,主表类似于一个壳子,逻辑上封装了子表,实际上数据都是存储在子表中的。

我们可以通过主表插入和查询数据,如果清楚分表规律,也可以直接操作子表。

子表2011年

?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 CREATE TABLE `account_2011` ( `id`  int(11) NOT NULL AUTO_INCREMENT , `namevarchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL , `money`  float NOT NULL , `tradeDate`  datetime NOT NULL PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARACTER SET=utf8 COLLATE=utf8_general_ci AUTO_INCREMENT=2 CHECKSUM=0 ROW_FORMAT=DYNAMIC DELAY_KEY_WRITE=0 ;

子表2012年

?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 CREATE TABLE `account_2012` ( `id`  int(11) NOT NULL AUTO_INCREMENT , `namevarchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL , `money`  float NOT NULL , `tradeDate`  datetime NOT NULL PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARACTER SET=utf8 COLLATE=utf8_general_ci AUTO_INCREMENT=2 CHECKSUM=0 ROW_FORMAT=DYNAMIC DELAY_KEY_WRITE=0 ;

主表,所有年

?
1 2 3 4 5 6 7 8 9 10 11 12 13 CREATE TABLE `account_all` ( `id`  int(11) NOT NULL AUTO_INCREMENT , `namevarchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL , `money`  float NOT NULL , `tradeDate`  datetime NOT NULL PRIMARY KEY (`id`) ) ENGINE=MRG_MYISAM DEFAULT CHARACTER SET=utf8 COLLATE=utf8_general_ci UNION=(`account_2011`,`account_2012`) INSERT_METHOD=LAST ROW_FORMAT=DYNAMIC ;

创建主表的时候有个INSERT_METHOD,指明插入方式,取值可以是:0 不允许插入;FIRST 插入到UNION中的第一个表; LAST 插入到UNION中的最后一个表。

通过主表查询的时候,相当于将所有子表合在一起查询。这样并不能体现分表的优势,建议还是查询子表。

分区的几种方式

Range:

?
1 2 3 4 5 6 7 8 9 10 create table range(   id int(11),   money int(11) unsigned not null,   date datetime   )partition by range(year(date))(   partition p2007 values less than (2008),   partition p2008 values less than (2009),   partition p2009 values less than (2010)   partition p2010 values less than maxvalue );

List:

?
1 2 3 4 5 6 7 create table list(   a int(11),   b int(11)   )(partition by list (b)   partition p0 values in (1,3,5,7,9),   partition p1 values in (2,4,6,8,0)  );

Hash:

?
1 2 3 4 5 create table hash(   a int(11),   b datetime   )partition by hash (YEAR(b)   partitions 4;

Key:

?
1 2 3 4 5 create table t_key(   a int(11),   b datetime)   partition by key (b)   partitions 4;

分区管理

新增分区

 
1 2 ALTER TABLE sale_data ADD PARTITION (PARTITION p201010 VALUES LESS THAN (201011));

删除分区
--当删除了一个分区,也同时删除了该分区中所有的数据。
ALTER TABLE sale_data DROP PARTITION p201010;

分区的合并
下面的SQL,将p201001 - p201009 合并为3个分区p2010Q1 - p2010Q3

 
1 2 3 4 5 6 7 8 9 ALTER TABLE sale_data REORGANIZE PARTITION p201001,p201002,p201003, p201004,p201005,p201006, p201007,p201008,p201009 INTO ( PARTITION p2010Q1 VALUES LESS THAN (201004), PARTITION p2010Q2 VALUES LESS THAN (201007), PARTITION p2010Q3 VALUES LESS THAN (201010) );

mysql分表和表分区详解

标签:

人气教程排行