shardingjdbc使用详解

1.在已有的项目中添加jar包依赖

<dependency>
                <groupId>org.apache.shardingsphere</groupId>
                <artifactId>sharding-jdbc-spring-boot-starter</artifactId>
                <version>4.0.0-RC1</version>
            </dependency>

2.Java方法添加分片配置


    @Bean(name = "myDataSource")
    public DataSource getShardingDataSource(@Qualifier("dataSourceOld") DataSource dataSource01) throws SQLException {
        ShardingRuleConfiguration shardingRuleConfig = new ShardingRuleConfiguration();
        shardingRuleConfig.getTableRuleConfigs().add(getOrderTableRuleConfiguration());
        shardingRuleConfig.getBindingTableGroups().add("bqhealth_cloud_main_index");
        shardingRuleConfig.setDefaultTableShardingStrategyConfig(new StandardShardingStrategyConfiguration("type", new MainIndexPreciseShardingAlgorithm()));
        Properties properties = new Properties();
        properties.setProperty("sql.show", sqlShow);
        return ShardingDataSourceFactory.createDataSource(createDataSourceMap(dataSource01), shardingRuleConfig, properties);
    }

    TableRuleConfiguration getOrderTableRuleConfiguration() {
        TableRuleConfiguration result = new TableRuleConfiguration("main_index", "db.main_index_${0..2}");
        return result;
    }

    Map<String, DataSource> createDataSourceMap(DataSource dataSource) {
        Map<String, DataSource> result = new HashMap<>();
        result.put("db", dataSource);
        return result;
    }

3.添加分片策略类

@Slf4j
public class MainIndexPreciseShardingAlgorithm implements PreciseShardingAlgorithm<Integer> {

    @Override
    public String doSharding(Collection<String> availableTargetNames, PreciseShardingValue<Integer> shardingValue) {

        for (String tableName : availableTargetNames) {
            if (tableName.endsWith(shardingValue.getValue() + "")) {
            	// 添加分片规则
                //log.info("doSharding >> shardingValue = {}, tableName = {}", shardingValue, tableName);
                return tableName;
            }
        }
        throw new IllegalArgumentException();
    }

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值