news 2026/7/1 22:51:33

ShardingSphere分库分表实战

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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目前支持所有数据库类型。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/7/1 17:18:22

2025如何选择适合企业规模和需求的财税外包服务

随着企业不断发展,财税管理已成为不可忽视的重要部分。尤其对于中小型企业来说,如何选择一款既能保证税务合规又能够提供个性化解决方案的财税服务显得尤为重要。在众多的财税服务提供商中,如何在定制化和标准化服务之间做出正确选择?本文将帮助您解答这一问题,并为您推荐…

作者头像 李华
网站建设 2026/7/1 14:05:15

【紧急必读】R Shiny多模态更新卡顿?这4个性能优化方案必须掌握

第一章:R Shiny多模态更新卡顿问题的现状与挑战在构建交互式数据可视化应用时,R Shiny 成为数据科学家和开发者的首选工具。然而,随着应用复杂度提升,尤其是涉及多模态输入(如文件上传、滑块调节、下拉选择等&#xff…

作者头像 李华
网站建设 2026/7/1 22:25:01

《长安二十四计》盛大启幕,徐璐担纲女主,携手成毅开启长安风云

古装权谋大剧《长安二十四计》于12月12日正式开播,登陆央视八套黄金强档,并在优酷、咪咕等网络平台同步上线,拉开了这幅描绘盛唐智计风云的磅礴画卷。该剧由成毅、徐璐分别担任男女主,更云集了刘奕君、王劲松、倪大红、张涵予等十…

作者头像 李华
网站建设 2026/7/1 22:25:00

【Excel VBA 编程】第59讲:VBA正则的隐形助手——非捕获组(?:)

上一期讲到了捕获组,它尽职尽责地找到我们关心的文本模式,并将其分门别类地记录到 SubMatches 集合中。然而,当匹配逻辑变得复杂时,这位“助手”过于细致的记录有时反而会成为一种负担什么是非捕获组为了卸下负担,解决…

作者头像 李华
网站建设 2026/7/1 17:12:08

构建高效协作的软件测试团队:策略与实践

在当今快速迭代的软件开发环境中,测试团队不再是简单的“bug发现者”,而是保障产品质量、推动技术创新的关键力量。随着敏捷开发、DevOps和持续集成/持续部署(CI/CD)的普及,测试工作面临着更高的效率要求和更复杂的协作…

作者头像 李华
网站建设 2026/6/30 19:49:12

为什么你的Rust PHP扩展总是崩溃?深入调试核心函数的3大方法

第一章:为什么你的Rust PHP扩展总是崩溃?在尝试将 Rust 与 PHP 集成以提升性能时,许多开发者遭遇运行时崩溃、段错误或不可预测的行为。根本原因往往并非语言本身的问题,而是对 PHP 扩展生命周期和内存管理模型的误解。不正确的内…

作者头像 李华