springboot使用sharding-jdbc分库分表

1,引入依赖

<dependency>
    <groupId>io.shardingsphere</groupId>
    <artifactId>sharding-core</artifactId>
    <version>2.0.3</version>
</dependency>

2,配置数据源

取消springboot自动配置的数据源:删除application.yml里的spring.datasource节点、@EnableJpaRepositories等默认配置。

新增sharding.jdbc.datasource配置:

sharding: 
  jdbc: 
    datasource: 
      driverClassName: com.mysql.jdbc.Driver
      url: jdbc:mysql://localhost/demo
      username: root
      password: 123456

3,新建sharding-jdbc数据源

@Configuration
public class DataSourceConfig {
	/**
	 * 生成分表的数据源
	 * @return
	 * @throws SQLException
	 */
	@Bean("shardingDataSource")
	public DataSource buildShardingDataSource() throws SQLException {
        ShardingRuleConfiguration shardingRuleConfig;
        shardingRuleConfig = new ShardingRuleConfiguration();
        shardingRuleConfig.getTableRuleConfigs().add(getOrderTableRuleConfiguration());
        shardingRuleConfig.getBindingTableGroups().add("wc_order");
        shardingRuleConfig.setDefaultTableShardingStrategyConfig(
        		new StandardShardingStrategyConfiguration(
        				"created_time", 
        				TableShardingAlgorithm.class.getName(), TableShardingAlgorithm.class.getName()));
        return new ShardingDataSource(shardingRuleConfig.build(createDataSourceMap()));
	}
	private Map<String, DataSource> createDataSourceMap() {
        Map<String, DataSource> result = new HashMap<>();
        result.put("ds_0", createDataSource());
        return result;
    }
    /**
     * 设置表的node
     * @return
     */
    @Bean
    TableRuleConfiguration getOrderTableRuleConfiguration() {
        TableRuleConfiguration orderTableRuleConfig = new TableRuleConfiguration();
        orderTableRuleConfig.setLogicTable("wc_order");
        orderTableRuleConfig.setActualDataNodes("ds_0.wc_order_2018, ds_0.wc_order_2019");
        return orderTableRuleConfig;
    }
	@Bean
	@Primary
	@ConfigurationProperties("sharding.jdbc.datasource")
	public DataSo
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值