Sharding中怎么利用JDBC实现强制路由
发表于:2025-12-02 作者:千家信息网编辑
千家信息网最后更新 2025年12月02日,这篇文章给大家介绍Sharding中怎么利用JDBC实现强制路由,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。分库策略package com.zero.sharding.shar
千家信息网最后更新 2025年12月02日Sharding中怎么利用JDBC实现强制路由
这篇文章给大家介绍Sharding中怎么利用JDBC实现强制路由,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
分库策略
package com.zero.sharding.shardingrule;import java.util.Collection;import org.apache.shardingsphere.api.sharding.hint.HintShardingAlgorithm;import org.apache.shardingsphere.api.sharding.hint.HintShardingValue;import com.google.common.collect.Sets;public class UserIdDataBaseHintAlgorithm implements HintShardingAlgorithm{ @Override public Collection doSharding(Collection availableTargetNames, HintShardingValue shardingValue) { Collection databaseSet = Sets.newConcurrentHashSet(); Collection orderIds = shardingValue.getValues(); for(Long orderId:orderIds){ if( orderId == 1l){ databaseSet.add("sharding1"); } } //TODO 根据传进来的分片值 路由到对应的物理库 return databaseSet; }}
分表策略
package com.zero.sharding.shardingrule;import java.util.Collection;import java.util.List;import org.apache.shardingsphere.api.sharding.hint.HintShardingAlgorithm;import org.apache.shardingsphere.api.sharding.hint.HintShardingValue;import com.google.common.collect.Sets;public class OrderIdTableHintAlgorithm implements HintShardingAlgorithm{ @Override public Collection doSharding(Collection availableTargetNames, HintShardingValue shardingValue) { Collection tableSet = Sets.newConcurrentHashSet(); Collection orderIds = shardingValue.getValues(); for(Long orderId:orderIds){ if( orderId == 2l){ tableSet.add("t_order0"); } } //TODO 根据传进来的分片值 路由到对应的物理表 return tableSet; }}
配置
#数据源spring.shardingsphere.datasource.names=sharding0,sharding1#默认数据源spring.shardingsphere.sharding.default-data-source-name=sharding0# 显示sqlspring.shardingsphere.props.sql.show=true#sharding0数据源配置spring.shardingsphere.datasource.sharding0.type=com.alibaba.druid.pool.DruidDataSourcespring.shardingsphere.datasource.sharding0.driver-class-name=com.mysql.cj.jdbc.Driverspring.shardingsphere.datasource.sharding0.url=jdbc:mysql://**:3306/sharding0?useUnicode=true&characterEncoding=utf8&autoReconnect=true&allowMultiQueries=true&serverTimezone=Asia/Shanghai&zeroDateTimeBehavior=CONVERT_TO_NULLspring.shardingsphere.datasource.sharding0.username=rootspring.shardingsphere.datasource.sharding0.password=**#sharding1 数据源配置spring.shardingsphere.datasource.sharding1.type=com.alibaba.druid.pool.DruidDataSourcespring.shardingsphere.datasource.sharding1.driver-class-name=com.mysql.cj.jdbc.Driverspring.shardingsphere.datasource.sharding1.url=jdbc:mysql://**:3306/sharding1?useUnicode=true&characterEncoding=utf8&autoReconnect=true&allowMultiQueries=true&serverTimezone=Asia/Shanghai&zeroDateTimeBehavior=CONVERT_TO_NULLspring.shardingsphere.datasource.sharding1.username=rootspring.shardingsphere.datasource.sharding1.password=**#hint 强制路由spring.shardingsphere.sharding.tables.t_order.database-strategy.hint.algorithm-class-name=com.zero.sharding.shardingrule.UserIdDataBaseHintAlgorithmspring.shardingsphere.sharding.tables.t_order.table-strategy.hint.algorithm-class-name=com.zero.sharding.shardingrule.OrderIdTableHintAlgorithm# 分布式主键 内置的支持这三种 SNOWFLAKE/UUID/LEAF_SEGMENTspring.shardingsphere.sharding.tables.t_order.key-generator.column=idspring.shardingsphere.sharding.tables.t_order.key-generator.type=SNOWFLAKE
使用示例
@Test public void testShardingRead(){ OrderExample ex = new OrderExample(); ex.createCriteria().andUserIdEqualTo(1l).andOrderIdEqualTo(1l); HintManager hintManager = HintManager.getInstance(); hintManager.addDatabaseShardingValue("t_order", 1l); hintManager.addTableShardingValue("t_order", 2l); List orders = orderMapper.selectByExample(ex); orders.stream().forEach(o->{ System.out.println("userId:"+o.getUserId() + " orderId:" + o.getOrderId()); }); hintManager.close(); } 关于Sharding中怎么利用JDBC实现强制路由就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
路由
数据
数据源
强制
配置
内容
更多
物理
策略
帮助
不错
兴趣
分布式
分库
分表
小伙
小伙伴
文章
知识
示例
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
小艺小艺服务器开小差
oracle数据库查询官网
微信淘宝客软件开发
盛途互联网跟青岛科技大学
.net软件开发找工作
存储优化数据库
昆明分布式服务器方案
网络安全维护规范
济南app软件开发服务公司
莱芜市网络安全宣传周
服务器管理怎么说
软件开发公司行业
勤哲服务器费用
查询到另一数据库
上诉状 软件开发退款
互联网科技周刊
网络技术基础实验视频教程
网络安全错误711
广东金众互联网信息科技有限公司
stm32串口7位数据库
文件存储用什么数据库
互联网科技接地气
如何配置管理和应用服务器
机载加固式服务器
网络安全防护典型案例
网络安全教育课题立项申请
江西智慧人口gis系统软件开发
卓健科技互联网医院app
别来无恙吉他谱软件开发
网络安全十个小技巧