BlueXIII's Blog

热爱技术,持续学习

0%

阿里云DRDS分库分表

以下大部分内容非原创,整理自阿里云官方文档

单库单表

建一张单库单表,不做任何拆分。

1
2
3
4
5
6
CREATE TABLE single_tbl(
id int,
name varchar(30),
primary key(id)
);
show topology from single_tbl;
1
2
3
4
5
CREATE TABLE normal_table(
id int,
name varchar(30),
primary key(id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

分库不分表

假设已经建好的分库数为 8,建一张表,只分库不分表,分库方式为根据 id 列哈希。

1
2
3
4
5
6
7
CREATE TABLE multi_db_single_tbl(
id int,
name varchar(30),
primary key(id)
) dbpartition by hash(id);

show topology from multi_db_single_tbl;

分库分表

使用哈希函数做拆分

1
2
3
4
5
6
7
8
CREATE TABLE multi_db_multi_tbl(
id int auto_increment,
bid int,
name varchar(30),
primary key(id)
) dbpartition by hash(id) tbpartition by hash(bid) tbpartitions 3;

show topology from multi_db_multi_tbl;

使用双字段哈希函数做拆分

1
2
3
4
5
6
7
8
9
create table test_order_tb (  
id int,
seller_id varchar(30) DEFAULT NULL,
buyer_id varchar(30) DEFAULT NULL,
create_time datetime DEFAULT NULL,
primary key(id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 dbpartition by RANGE_HASH(seller_id,buyer_id, 10) tbpartition by RANGE_HASH(seller_id,buyer_id, 10) tbpartitions 3;

show topology from multi_db_multi_tbl;

使用日期做拆分

可以使用日期函数 MM/DD/WEEK/MMDD 来作为分表的拆分算法

1
2
3
4
5
6
7
8
CREATE TABLE user_log(
userId int,
name varchar(30),
operation varchar(30),
actionDate DATE
) dbpartition by hash(userId) tbpartition by WEEK(actionDate) tbpartitions 7;

show topology from user_log;
1
2
3
4
5
6
7
8
9
CREATE TABLE user_log2(
userId int,
name varchar(30),
operation varchar(30),
actionDate DATE
) dbpartition by hash(userId) tbpartition by MM(actionDate) tbpartitions 12;

show topology from user_log2;

默认使用主键作为拆分字段

当拆分算法不指定任何拆分字段时,系统默认使用主键作为拆分字段。

1
2
3
4
5
CREATE TABLE prmkey_tbl(
id int,
name varchar(30),
primary key(id)
) dbpartition by hash();
1
2
3
4
5
CREATE TABLE prmkey_multi_tbl(
id int,
name varchar(30),
primary key(id)
) dbpartition by hash() tbpartition by hash() tbpartitions 3;

广播表

子句BROADCAST用来指定创建广播表。广播表是指将这个表复制到每个分库上,在分库上通过同步机制实现数据一致,有秒级延迟。
这样做的好处是可以将 JOIN 操作下推到底层的 RDS(MySQL),来避免跨库 JOIN。

1
2
3
4
5
CREATE TABLE brd_tbl(
id int,
name varchar(30),
primary key(id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 BROADCAST;

直接在客户端使用DDL建表好像并不成功,尽量使用WEB控制台建表

其它操作

查看物理表的拓扑结构

1
SHOW TOPOLOGY FROM multi_db_multi_tbl;

查看逻辑表是否创建成功

1
CHECK TABLE multi_db_multi_tbl;