以下大部分内容非原创,整理自阿里云官方文档
单库单表
建一张单库单表,不做任何拆分。
CREATE TABLE single_tbl(
id int,
name varchar(30),
primary key(id)
);
show topology from single_tbl;
CREATE TABLE normal_table(
id int,
name varchar(30),
primary key(id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
分库不分表
假设已经建好的分库数为 8,建一张表,只分库不分表,分库方式为根据 id 列哈希。
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;
分库分表
使用哈希函数做拆分
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;
使用双字段哈希函数做拆分
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 来作为分表的拆分算法
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;
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;
默认使用主键作为拆分字段
当拆分算法不指定任何拆分字段时,系统默认使用主键作为拆分字段。
CREATE TABLE prmkey_tbl(
id int,
name varchar(30),
primary key(id)
) dbpartition by hash();
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。
CREATE TABLE brd_tbl(
id int,
name varchar(30),
primary key(id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 BROADCAST;
直接在客户端使用DDL建表好像并不成功,尽量使用WEB控制台建表
其它操作
查看物理表的拓扑结构
SHOW TOPOLOGY FROM multi_db_multi_tbl;
查看逻辑表是否创建成功
CHECK TABLE multi_db_multi_tbl;