spring-boot-route(十)多数据源切换
前面我们已经介绍了三种方式来操作数据库,在实际开发中,往往会出现一个服务连接多个数据库的需求,这时候就需要在项目中进行灵活切换数据源来完成多个数据库操作。这一章中,我们使用jdbcTemplate来学习多数据源的配置。
一 准备工作
1.1 建库、建表
我们新建两个库db1
和db2
,数据结构还是用前面演示的,分别在两个库中新建表student
。
1.2 引入mysql和jdbcTemplate依赖
1.3 写入两个数据源配置
二 多数据源配置
@Primary:表示主的,即出现多个bean的时候如果不指定具体的bean,则会采用这个
@bean:标注为一个bean,如果不指定name属性,则会使用创建bean方法的名字做为bean的名字
@ConfigurationProperties:读取配置文件
三 配置JdbcTemplate对象
@Qualifier:bean类型相同后,指定使用的bean的name
四 测试类
4.1 测试@Primary属性
不指定使用哪个JdbcTemplate对象时,会使用标注了@Primary属性的对象
4.2 测试多数据源
这里分享一道面试题:@Autowired 与@Resource有什么区别?
@Autowired是Spring提供的,@Resource是JDK提供的;
@Autowired是根据bean的类型匹配的,@Resource是根据bean的name匹配的;
如果@Autowird想要根据name匹配应该怎么做呢?
配合@Qualifier注解指定bean的name
使用变量名称作为bean的id,@Autowired如果匹配到多个符合条件的对象后,会自动根据变量名称做为bean的id继续匹配。我们在4.2中采用的就是这种方式。
此是spring-boot-route系列的第十篇文章,这个系列的文章都比较简单,主要目的就是为了帮助初次接触Spring Boot 的同学有一个系统的认识。本文已收录至我的github,欢迎各位小伙伴star
!
github:https://github.com/binzh303/spring-boot-route
点关注、不迷路
如果觉得文章不错,欢迎关注、*点赞*、收藏,你们的支持是我创作的动力,感谢大家。
如果文章写的有问题,请不要吝啬,欢迎留言指出,我会及时核查修改。
如果你还想更加深入的了解我,可以微信搜索「Java旅途」进行关注。回复「1024」即可获得学习视频及精美电子书。每天7:30准时推送技术文章,让你的上班路不在孤独,而且每月还有送书活动,助你提升硬实力!
版权声明: 本文为 InfoQ 作者【Java旅途】的原创文章。
原文链接:【http://xie.infoq.cn/article/b33c58b820cced278f4b80925】。
本文遵守【CC-BY 4.0】协议,转载请保留原文出处及本版权声明。
评论