一个数据库由很多表
的构成,每个表对应着不同的业务,垂直切分
是指按照业务
将表进行分类,分布到不同 的数据库上面,这样也就将数据
或者说压力
分担到不同的库
上面,如下图:
系统
被切分成了,用户,订单交易,支付几个模块。
1、 如何划分表
一个问题:在两台主机
上的两个数据库中的表,能否
关联查询?
答案:不可以关联查询。
分库的原则:
有紧密关联关系
的表应该在一个库里,相互没有关联关系
的表可以分到不同
的库里。
表sql
#客户表 rows:20万
CREATE TABLE customer(
id INT AUTO_INCREMENT,
NAME VARCHAR(200),
PRIMARY KEY(id)
);
#订单表 rows:600万
CREATE TABLE orders(
id INT AUTO_INCREMENT,
order_type INT,
customer_id INT,
amount DECIMAL(10,2),
PRIMARY KEY(id)
);
#订单详细表 rows:600万
CREATE TABLE orders_detail(
id INT AUTO_INCREMENT,
detail VARCHAR(2000),
order_id INT,
PRIMARY KEY(id)
);
#订单状态字典表 rows:20
CREATE TABLE dict_order_type(
id INT AUTO_INCREMENT,
order_type VARCHAR(200),
PRIMARY KEY(id)
);
以上四个表如何分库?客户表分在一个数据库,另外三张都需要关联查询
,分在另外一个数据库
2 实现分库
①、 修改 schema 配置文件
<schema name="TESTDB" checkSQLschema="false" sqlMaxLimit="100" dataNode="dn1">
<!--主要修改位置 , 表示 customer 在dn2 节点中 的 orders 数据库中 --->
<table name="customer" dataNode="dn2" ></table>
</schema>
<!--数据库节点 节点间是不存在 主从复制的 -->
<dataNode name="dn1" dataHost="host1" database="testdb" />
<dataNode name="dn2" dataHost="host2" database="orders" />
<dataHost name="host1" maxCon="1000" minCon="10" balance="0" dbType="mysql"
dbDriver="native" switchType="1" slaveThreshold="100">
<!--心跳检查 -->
<heartbeat>select user()</heartbeat>
<!-- can have multi write hosts -->
<writeHost host="hostM1" url="66.88.88.169:3306" user="root" password="mysql">
<!-- can have multi read hosts -->
</writeHost>
</dataHost>
<dataHost name="host2" maxCon="1000" minCon="10" balance="0"
dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100">
<!--心跳检查 -->
<heartbeat>select user()</heartbeat>
<!-- can have multi write hosts -->
<writeHost host="hostM2" url="66.88.88.171:3306" user="root" password="mysql">
<!-- can have multi read hosts -->
</writeHost>
</dataHost>
②、 新增两个空白库
分库操作不是
在原来的老数据库上
进行操作,需要准备两台机器
分别安装新的数据库
#在数据节点dn1、dn2
上分别创建数据库 orders
CREATE DATABASE orders;
③、启动mycat、 访问 Mycat 进行分库
访问 Mycat
mysql -umycat -p123456 -h 192.168.140.128 -P 8066
切换到 TESTDB
扫描二维码关注公众号,回复:
10373500 查看本文章
- 创建 4 张表
- 查看表信息,可以看到
成功分库