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/+映射路径+参数,然后回车,查看数据库即可得到结果