springboot整合多数据源

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/+映射路径+参数,然后回车,查看数据库即可得到结果
在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值