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

单库单表

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

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;

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐