mycat单库多表--编程指定运算和取模入库运算

本文介绍了MySQL中的两种单库多表分片策略:按商户ID动态分表和取模入库运算。动态分表策略允许按商户ID进行分表,避免数据错乱,适合数据量大的场景。取模入库则通过商户ID取模决定数据存储位置,但扩展性较差。文章通过配置示例和SQL测试,详细解析了这两种策略的实现和效果。
摘要由CSDN通过智能技术生成

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这样的取模方式进行入库。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值