前面咱们已经介绍了三种方式来操做数据库,在实际开发中,每每会出现一个服务链接多个数据库的需求,这时候就须要在项目中进行灵活切换数据源来完成多个数据库操做。这一章中,咱们使用jdbcTemplate来学习多数据源的配置。java
一 准备工做
1.1 建库、建表
咱们新建两个库db1
和db2
,数据结构仍是用前面演示的,分别在两个库中新建表student
。mysql
CREATE TABLE `student` ( `student_id` int(30) NOT NULL AUTO_INCREMENT, `age` int(1) DEFAULT NULL COMMENT '年龄', `name` varchar(45) DEFAULT NULL COMMENT '姓名', `sex` int(1) DEFAULT NULL COMMENT '性别:1:男,2:女,0:未知', `create_time` datetime DEFAULT NULL COMMENT '建立时间', `status` int(1) DEFAULT NULL COMMENT '状态:1:正常,-1:删除', PRIMARY KEY (`student_id`) ) ENGINE=InnoDB CHARSET=utf8mb4 CHECKSUM=1 DELAY_KEY_WRITE=1 ROW_FORMAT=DYNAMIC COMMENT='学生表'
1.2 引入mysql和jdbcTemplate依赖
<dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.11</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jdbc</artifactId> </dependency>
1.3 写入两个数据源配置
spring: datasource: db1: driver-class-name: com.mysql.cj.jdbc.Driver jdbc-url: jdbc:mysql://localhost:3306/db1 username: root password: root db2: driver-class-name: com.mysql.cj.jdbc.Driver jdbc-url: jdbc:mysql://localhost:3306/db2 username: root password: root
二 多数据源配置
@Configuration public class DataSourceConfig { @Primary @Bean @ConfigurationProperties(prefix = "spring.datasource.db1") public DataSource db1DataSource(){ return DataSourceBuilder.create().build(); } @Bean @ConfigurationProperties(prefix = "spring.datasource.db2") public DataSource db2DataSource(){ return DataSourceBuilder.create().build(); } }
- @Primary:表示主的,即出现多个bean的时候若是不指定具体的bean,则会采用这个
- @bean:标注为一个bean,若是不指定name属性,则会使用建立bean方法的名字作为bean的名字
- @ConfigurationProperties:读取配置文件
三 配置JdbcTemplate对象
@Configuration public class DataSourceConfig { @Bean public JdbcTemplate db1JdbcTemplate(@Qualifier("db1DataSource") DataSource dataSource){ return new JdbcTemplate(dataSource); } @Primary @Bean public JdbcTemplate db2JdbcTemplate(@Qualifier("db2DataSource") DataSource dataSource){ return new JdbcTemplate(dataSource); } }
- @Qualifier:bean类型相同后,指定使用的bean的name
四 测试类
4.1 测试@Primary属性
不指定使用哪一个JdbcTemplate对象时,会使用标注了@Primary属性的对象git
@SpringBootTest class SpringBootDatasourceApplicationTests { @Autowired private JdbcTemplate jdbcTemplate; @Test void testPrimary() { jdbcTemplate.update("insert into student(name,age) values(?,?)",new Object[]{"Java旅途",18}); } }
4.2 测试多数据源
@SpringBootTest class SpringBootDatasourceApplicationTests { @Autowired private JdbcTemplate db1JdbcTemplate; @Autowired private JdbcTemplate db2JdbcTemplate; @Autowired private JdbcTemplate jdbcTemplate; @Test void contextLoads() { db1JdbcTemplate.update("insert into student(name,age) values(?,?)",new Object[]{"Java旅途",18}); db2JdbcTemplate.update("insert into student(name,age) values(?,?)",new Object[]{"Java旅途",18}); } } }
这里分享一道面试题:@Autowired 与@Resource有什么区别?github
@Autowired是Spring提供的,@Resource是JDK提供的;面试
@Autowired是根据bean的类型匹配的,@Resource是根据bean的name匹配的;redis
若是@Autowird想要根据name匹配应该怎么作呢?spring
- 配合@Qualifier注解指定bean的name
- 使用变量名称做为bean的id,@Autowired若是匹配到多个符合条件的对象后,会自动根据变量名称作为bean的id继续匹配。咱们在4.2中采用的就是这种方式。
本文示例代码已上传至github,点个star
支持一下!
Spring Boot系列教程目录
spring-boot-route(一)Controller接收参数的几种方式sql
spring-boot-route(二)读取配置文件的几种方式数据库
spring-boot-route(五)整合Swagger生成接口文档
spring-boot-route(六)整合JApiDocs生成接口文档
spring-boot-route(七)整合jdbcTemplate操做数据库
spring-boot-route(八)整合mybatis操做数据库
spring-boot-route(九)整合JPA操做数据库
spring-boot-route(十一)数据库配置信息加密
spring-boot-route(十二)整合redis作为缓存
spring-boot-route(十三)整合RabbitMQ
spring-boot-route(十五)整合RocketMQ
spring-boot-route(十六)使用logback生产日志文件
spring-boot-route(十七)使用aop记录操做日志
spring-boot-route(十八)spring-boot-adtuator监控应用
spring-boot-route(十九)spring-boot-admin监控服务
spring-boot-route(二十)Spring Task实现简单定时任务
spring-boot-route(二十一)quartz实现动态定时任务
spring-boot-route(二十二)实现邮件发送功能
这个系列的文章都是工做中频繁用到的知识,学完这个系列,应付平常开发绰绰有余。若是还想了解其余内容,扫面下方二维码告诉我,我会进一步完善这个系列的文章!