Sharding中怎么利用JDBC实现强制路由
发表于:2025-02-01 作者:千家信息网编辑
千家信息网最后更新 2025年02月01日,这篇文章给大家介绍Sharding中怎么利用JDBC实现强制路由,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。分库策略package com.zero.sharding.shar
千家信息网最后更新 2025年02月01日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); Listorders = orderMapper.selectByExample(ex); orders.stream().forEach(o->{ System.out.println("userId:"+o.getUserId() + " orderId:" + o.getOrderId()); }); hintManager.close(); }
关于Sharding中怎么利用JDBC实现强制路由就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
路由
数据
数据源
强制
配置
内容
更多
物理
策略
帮助
不错
兴趣
分布式
分库
分表
小伙
小伙伴
文章
知识
示例
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
盛世加贝尔网络技术有限公司
保护网络安全的手抄报怎么画
eos使用什么数据库
sql数据库应用考试
哪个软件有oracle数据库
犀牛软件开发app
数据库怎么用代码建库
珠海工商银行软件开发部
5g时代网络安全有何变数
t 数据库修复
工控网络安全技术规格书
云服务器vps管理系统
无法建立服务器安全连接
软件开发相关知识点
华为互联网正业科技
比较正规的服务器地址
银行数据库的作用
各大数据库对比
云服务器能用内网吗
用友t6手动备份数据库
咸宁市生态环境局网络安全
网站和服务器的关系
不属于精益软件开发原则
楚雄师院图书馆数据库
舒兰市政法委网络安全
我的世界手机版养肝服务器
我的世界免费服务器1.10.2
北仑安卓软件开发周期
死神来了游戏连不上服务器
网络安全国信安