1、单库多表:编程指定运算:
场景:此运算可以指定商户入某张表,而且可以实现动态加表,不会使数据错乱。比如当多商户入驻后,order表数据超过千万级的时候,查询和更新都是按照商户ID来进行操作,那么就可以按商户ID进行分表,例如商户ID为1的交易记录存储到order_1表,同理商户ID为2的存储到order_2中,以此类推可以自定义按照商户的ID进行放入新建立的表中。
实现:在MySQL中建立数据实例order,并且新建order_0-order_3共四张表如下:
配置真实服务器信息
通过修改conf/schema.xml
配置路由规则
在schema.xml中我们已经制定了order表存储的节点,且设置了路由规则的名称sharding-substring-partition,然后我们设置该规则具体的策略。
修改conf/rule.xml,配置规则如下,注意我们是按tenant_id列来进行规则应用的
参数说明:
startIndex:代表从第几位开始截取
Size:一共截取几位
partitionCount:分表的数量,注意(如果想自定义表数,那么mycat的版本一定要是1.6.5以上,不然会启动报错)
defaultPartition:默认数据落入的某个分表
比如:tenant_id=01,在此配置中代表根据tenant_id中从
startIndex=0,开始,截取 siz=2 位数字即 01,01就是获取的分区,如果没传默认分配到 defaultPartition。
测试:
启动MyCat后,然后使用Navicat连接MyCat虚拟的数据库即可,执行下面的sql语句
Order_0的数据如下:
Order_1的数据如下:
其他两个库也是按此规则运作的,即数据落入order_$0-3表。
2、单库多表:取模入库运算:
这个是通过取模的方式进行入表,实现自由的扩表比较困难,因为加表后,取模方式会使数据入错表。
配置真实服务器信息
通过修改conf/schema.xml,更换rule的算法
配置路由规则
在schema.xml中我们已经制定了order表存储的节点,且设置了路由规则的名称rule-order,然后我们设置该规则具体的策略。
修改conf/rule.xml,配置规则如下,注意我们是按tenant_id列来进行规则应用的
测试Sql语句:
Order_0的数据如下:
其他三个库的数据也根据1-4这样的取模方式进行入库。