springboot整合多数据源

本文详细介绍了如何在SpringBoot项目中整合多个数据源,包括配置步骤、依赖引入及代码实现,通过具体示例展示了如何操作不同数据库。

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

springboot整合多数据源

1.在数据库建立两个数据库,如下所示:

在这里插入图片描述

2.建立springboot项目,添加配置。

2.1在pom.xml中,引入以下依赖(使用的是springboot 2.1.1.RELEASE版本

	<dependency>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-web</artifactId>
	</dependency>
	<dependency>
		<groupId>org.mybatis.spring.boot</groupId>
		<artifactId>mybatis-spring-boot-starter</artifactId>
		<version>1.3.2</version>
	</dependency>
	</dependency>
	<dependency>
		<groupId>mysql</groupId>
		<artifactId>mysql-connector-java</artifactId>
		<version>5.1.6</version><!-- 不添加启动会保存-->
		<scope>runtime</scope>
	</dependency>

2.2 在application.properties文件中配置数据源

#数据源1
spring.datasource.test01.jdbc-url=jdbc:mysql://localhost:3306/test01
spring.datasource.test01.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.test01.username=root
spring.datasource.test01.password=root

#数据源2
spring.datasource.test02.jdbc-url=jdbc:mysql://localhost:3306/test02
spring.datasource.test02.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.test02.username=root
spring.datasource.test02.password=root

注:在2.0版本以后,使用spring.datasource.jdbc-url,使用spring.datasource.url会报错

2.3使用代码进行配置,区分数据源(根据包名进行区分)

@Configuration
@MapperScan(basePackages = “com.spring.test01”, sqlSessionFactoryRef = “test1SqlSessionFactory”)
public class TestDataSource01 {
/**
* 配置test01数据库
*
* @Primary 代表默认执行的数据库
* @return
*/
@Bean(name = “test01DataSource”)
@Primary
@ConfigurationProperties(prefix = “spring.datasource.test01”)
public DataSource tsetDataSource() {
return DataSourceBuilder.create().build();
}

/**
 * 会话
 * 
 * @param dataSource
 * @return
 * @throws Exception
 */
@Bean(name = "test1SqlSessionFactory")
@Primary
public SqlSessionFactory testSqlSessionFactory(@Qualifier("test01DataSource") DataSource dataSource)
		throws Exception {
	{
		SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
		bean.setDataSource(dataSource);
		return bean.getObject();
	}

}

/**
 * 事物
 * 
 * @param dataSource
 * @return
 */
@Bean(name = "test1TranssactionManager")
@Primary
public DataSourceTransactionManager testTranssactionManager(@Qualifier("test01DataSource") DataSource dataSource) {
	return new DataSourceTransactionManager(dataSource);
}

/**
 * 
 * @param factory
 * @return
 * @throws Exception
 */
@Bean("test1SqlSessionTemplate")
@Primary
public SqlSessionTemplate testSqlSessionTemplate(@Qualifier("test1SqlSessionFactory") SqlSessionFactory factory)
		throws Exception {
	return new SqlSessionTemplate(factory);
}

}
注:以上内容,配置2个数据源,则写两份,区分开来,同时,对其中一份的配置添加@Primary注解,另一则不需要,即默认使用的数据源。
2.4开始操作数据库
2.4.1
根据@ConfigurationProperties(prefix = “spring.datasource.test01”)进行建包
2.4.2
建好包之后按照mybatis使用进行操作数据库,如mapper文件中使用注解
@Insert(“insert into users(username,password) values(#{user.username},#{user.password})”)
int insertUser(@Param(“user”) User user);
2.4.3
在controller层分别调用方法来操作两个数据源
@RestController
public class UserController {

@Autowired
private User01Dao user01Dao;
@Autowired
private User02Dao user02Dao;

@RequestMapping("/inserUserTest01")
public String  inserUserTest01(User user) {
	user01Dao.insertUser(user);
	return "Success";
}

@RequestMapping("/inserUserTest02")
public String  inserUserTest02(User user) {
	user02Dao.insertUser(user);
	return "Success";
}


2.4.4
启动项目,在URL输入127.0.0.1:8080/+映射路径+参数,然后回车,查看数据库即可得到结果
在这里插入图片描述
在这里插入图片描述

springboot可以通过使用dynamic-datasource-spring-boot-starter来实现多数据源整合。该启动器基于springboot,可以快速集成多个数据源。一般的思路是根据自定义的配置数据源信息初始化数据源,并使用druid连接池和mybatis进行相关配置。引用 具体步骤可以包括以下几个方面: 1. 引入相关依赖:在项目的pom.xml文件中添加dynamic-datasource-spring-boot-starter、druid-spring-boot-starter和mybatis-spring-boot-starter等依赖。引用 2. 配置数据源信息:在application.yml或application.properties文件中配置多个数据源的信息,包括数据库的连接地址、用户名、密码等。可以使用@ConfigurationProperties注解来绑定配置文件中的数据源信息到对应的实体类中。 3. 初始化数据源:使用Configuration类来初始化数据源。可以自定义一个DynamicDataSourceConfig类,并在其中使用@Bean注解来配置数据源。在该类中可以通过读取配置文件的方式来获取数据源信息,并将其初始化为对应的数据源。 4. 配置mybatis:在application.yml或application.properties文件中配置mybatis的相关信息,如mapper的扫描路径等。 通过以上步骤,就可以实现springboot多数据源整合。当然,以上只是一个基本的思路,具体实现还需要根据项目的实际需求进行调整和扩展。引用<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [SpringBoot实现多数据源的两种方式](https://blog.youkuaiyun.com/m0_67401761/article/details/126114612)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [SpringBoot整合多数据源的两种方式](https://blog.youkuaiyun.com/hongs468/article/details/128469985)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值