springboot使用sharding-jdbc分库分表

本文介绍了如何在SpringBoot项目中使用Sharding-JDBC进行分库分表操作,包括引入依赖、配置数据源、新建数据源以及分表规则的设定。同时,文章指出了Sharding-JDBC的一些限制,如不支持动态建表、特定SQL操作受限等,并分享了一个规避这些限制的方法,即采用双数据源策略,将订单表单独放在分表数据源中,其他表使用默认数据源,从而保持项目的正常运行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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.jdb
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值