请选择 进入手机版 | 继续访问电脑版

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

[复制链接]
东方龙头 发表于 2020-12-31 20:22:20 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题
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这样的取模方式举行入库。

来源:https://blog.csdn.net/u013705884/article/details/111944050
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

发布主题

专注素材教程免费分享
全国免费热线电话

18768367769

周一至周日9:00-23:00

反馈建议

27428564@qq.com 在线QQ咨询

扫描二维码关注我们

Powered by Discuz! X3.4© 2001-2013 Comsenz Inc.( 蜀ICP备2021001884号-1 )