当前位置: 首页 > news >正文

ShardingSphere分库分表实战

分库分表介绍

有关分库分表的介绍说明,参考下面文章:

https://blog.csdn.net/liangmengbk/article/details/155918663?spm=1001.2014.3001.5501

shardingsphere官网:

https://shardingsphere.apache.org/index_zh.html

分库分表实战

下面用一个操作的案例,说明如何用shardingsphere完成分库分表。

案例中用到的Java代码和SQL脚本,从下面的链接可以直接下载:

https://download.csdn.net/download/liangmengbk/92463969

数据库创建

为了能够清楚的看到分库分表的效果,需要准备两台电脑(服务器),分别安装MySQL。

第一台服务器做以下操作:

1.创建数据库,名称为mall_0

2.执行创建表的脚本

脚本执行完成后,会在数据库中创建两张表,如下图:

第二台服务器做以下操作:

1.创建数据库,名称为mall_1

2.执行创建表的脚本

脚本执行完成后,会在数据库中创建两张表,如下图:

以上操作完成后,数据库和表就创建好了。一共创建了两个数据库,每个数据库有两张表,一共四张表,四张表的字段完全一样。

在创建表时,有一点要注释,就是表的主键,不要设置自增,因为多个表都是自增的话,在查询时会出现主键重复的情况。用雪花算法来生成唯一的主键。

运行代码

把代码用idea打开,然后重点关注applicationContext.xml配置文件,这个文件是shardingsphere的核心配置文件

配置文件中的所有配置,都添加了中文注释说明,下面对配置中的重点内容进行说明:

1.定义两个数据源的链接信息

2.定义分库、分表、主键生成策略

3.将定义的数据源和各种策略应用到sharding-jdbc

上面的三步就是核心的配置,通过这些配置就告诉了sharding-jdbc,数据源有哪些,分库分表及主键生成策略是什么。

具体的配置内容,通过注释去理解就可以了,不做过多解释。

下面把代码运行起来,看看效果:

打开ShardingTest.java测试类,运行testBatchInsert方法,往表中插入一些测试数据。

观察控制台,看到测试通过,就说明数据已经插入完成。

查询表数据

通过查询表记录,可以看到在不同的数据库,不同的表中,一共插入了10条记录。

为什么10条记录分布在两台服务器的这两个表中呢?

这就是由配置文件中的分库分表策略控制的,当前的策略是:

1.当往表中插入记录时,如果user_id的值是偶数,则保存在ds0数据库中(第一台服务器),奇数保存在ds1数据库中(第二台服务器)。

2.当往表中插入记录时,如果order_id的值是偶数,则保存在t_order_0表中,奇数保存在t_order_1表中。

根据这个策略,数据就会被插入到不同数据库的不同表。

策略是可以调整的,根据实际情况进行调整,数据就会插入到不同的库和表中。

数据插入完成,下面看一下数据查询:

运行testQuery方法,观察控制台的输出结果:

数据库查询的结果打印出来了。

一共10条记录,也就说明是把两个数据库的记录都查询出来了。

总结

通过上面的操作,可以看到shardingsphere这个中间件,可以根据设置的策略把数据插入到不同的数据库和不同的表中。

在查询时,也是把多个数据源的不同表记录一起查询出来了。

更多的关于shardingsphere的用法,看官方文档。

shardingsphere目前支持所有数据库类型。

http://www.jsqmd.com/news/94626/

相关文章:

  • 基于协同过滤的微信小程序音乐推荐系统(源码+论文+部署+安装)
  • MAUI自动化测试框架选型对比(Xamarin.UITest vs .NET MAUI Test)
  • 10、全面解析Nagios配置与启动指南
  • 为什么你的协程不高效?深入理解纤维任务调度底层逻辑
  • 2025如何选择适合企业规模和需求的财税外包服务
  • QDK文档更新速递:2024年新增功能一览(限时解读)
  • Swagger UI 自定义请求头:从用户配置到请求注入的完整流程解析
  • 11、Nagios配置自动化工具指南
  • 揭秘环境监测中的时空异常:如何用R语言实现精准可视化与预警分析
  • 揭秘高精度农业监测系统:PHP如何实现毫秒级异常数据过滤
  • 【紧急必读】R Shiny多模态更新卡顿?这4个性能优化方案必须掌握
  • 农业试验数据处理指南(R语言方差分析核心技术大公开)
  • JAVA毕业设计257—基于Java+Springboot+vue3的高校招投标系统(源代码+数据库+开题)
  • swift中arview配置3d物体的碰撞事件,一定要配置name
  • n8n 2.0 中文汉化版一键部署教程 | 解除Execute Command限制
  • 太月香学新书《中国传统香学》首发亮相
  • 用梯形图+SCL玩转FactoryIO码垛控制
  • 泛型集合性能瓶颈,90%的开发者都忽略的3个关键点
  • 【Q#调试权威手册】:微软官方未公开的4个调试利器全曝光
  • IU5209:30V OVP,快充申请,1A,NTC及使能功能,4节锂电池充电管理芯片
  • 手把手教你编译PHP 8.6扩展(含10个实用调试技巧)
  • 十五五智能制造数字化工厂蓝图规划及推进路线:1 张蓝图、3 条主线、6 大系统、4 阶段路线
  • 某Boss直聘数据获取
  • 揭秘PHP 8.6性能瓶颈:如何利用新特性打造超强监控系统
  • 2025冬暖影展奔赴广州,以光影开启时空对话
  • 揭秘量子算法落地难题:3个关键突破点让你少走5年弯路
  • 为什么你的GraphQL API不够灵活?PHP字段别名设计的4个致命误区
  • 掌握这5种AOT调试黑科技,效率提升300%不是梦
  • 【紧急预警】物联网安全漏洞频发,部署时必须配置的4道防火墙
  • IntelliJ IDEA 安装 pmd-idea-1.9.0.zip 插件详细教程