Spring双数据库配置_PHP教程
Jul 20, 2016 am 10:58 AM
spring
为了
使用
双
可
多个
实现
我们
数据库
的
配置
有时候我们可能在一个项目中使用两个数据库,为了实现使用两个或多个数据库的功能,我们需要在Spring中配置相关信息。
首先是添加配置文件conf.properties
<ol class="dp-c"> <li class="alt"><span><span><bean><span class="string">"propertyConfigurer"</span><span> </span><span class="keyword">class</span><span>=</span><span class="string">"org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"</span><span>> </span></bean></span></span></li> <li><span> <property><span class="string">"locations"</span><span>> </span></property></span></li> <li class="alt"><span> <list> </list></span></li> <li><span> <value>classpath:config.properties</value> </span></li> <li class="alt"><span> </span></li> <li><span> </span></li> <li class="alt"><span> </span></li> </ol>
登录后复制
其次是添加数据源(${...}对应的是conf.properties中的配置信息)
<ol class="dp-c"> <li class="alt"><span><span><!--对应数据A的数据源--> </span></span></li> <li><span><bean><span class="string">"dataSource_A"</span><span> </span><span class="keyword">class</span><span>=</span><span class="string">"org.apache.commons.dbcp.BasicDataSource"</span><span>> </span></bean></span></li> <li class="alt"><span> <property><span class="string">"driverClassName"</span><span> value=</span><span class="string">"${A.driver_class}"</span><span> /> </span></property></span></li> <li><span> <property><span class="string">"url"</span><span> value=</span><span class="string">"${A.url}"</span><span> /> </span></property></span></li> <li class="alt"><span> <property><span class="string">"username"</span><span> value=</span><span class="string">"${A.username}"</span><span> /> </span></property></span></li> <li><span> <property><span class="string">"password"</span><span> value=</span><span class="string">"${A.password}"</span><span> /> </span></property></span></li> <li class="alt"><span> </span></li> <li><span><!--对应数据库B的数据源--> </span></li> <li class="alt"><span><bean><span class="string">"dataSource_B"</span><span> </span><span class="keyword">class</span><span>=</span><span class="string">"org.apache.commons.dbcp.BasicDataSource"</span><span>> </span></bean></span></li> <li><span> <property><span class="string">"driverClassName"</span><span> value=</span><span class="string">"${B.driver_class}"</span><span> /> </span></property></span></li> <li class="alt"><span> <property><span class="string">"url"</span><span> value=</span><span class="string">"${B.url}"</span><span> /> </span></property></span></li> <li><span> <property><span class="string">"username"</span><span> value=</span><span class="string">"${B.username}"</span><span> /> </span></property></span></li> <li class="alt"><span> <property><span class="string">"password"</span><span> value=</span><span class="string">"${B.password}"</span><span> /> </span></property></span></li> <li><span> </span></li> </ol>
登录后复制
之后是添加对应的sessionFactory:
<ol class="dp-c"> <li class="alt"><span><span><!-- A的sessionFactory --> </span></span></li> <li><span> <bean><span class="string">"sessionFactory_A"</span><span> </span><span class="keyword">class</span><span>=</span><span class="string">"moretv.commons.spring.hibernate3.AnnotationSessionFactoryBean"</span><span>> </span></bean></span></li> <li class="alt"><span> <property><span class="string">"dataSource"</span><span> ref=</span><span class="string">"dataSource_A"</span><span>/> </span></property></span></li> <li><span> </span></li> <li class="alt"><span><!-- B的sessionFactory --> </span></li> <li><span> <bean><span class="string">"sessionFactory_B"</span><span> </span><span class="keyword">class</span><span>=</span><span class="string">"moretv.commons.spring.hibernate3.AnnotationSessionFactoryBean"</span><span>> </span></bean></span></li> <li class="alt"><span> <property><span class="string">"dataSource"</span><span> ref=</span><span class="string">"dataSource_B"</span><span>/> </span></property></span></li> <li><span> </span></li> </ol>
登录后复制
在项目中的dao层有时会出现这样的配置信息:
<ol class="dp-c"> <li class="alt"><span><span><bean><span class="string">"XDao"</span><span> </span><span class="keyword">class</span><span> = </span><span class="string">"xxx.xxx.xDaoImpl"</span><span>> </span></bean></span></span></li> <li><span><property><span class="string">"sessionFactory"</span><span> ref=</span><span class="string">"sessionFactory"</span><span>></span></property> </span></li> <li class="alt"><span> </span></li> </ol>
登录后复制
为了实现使用两个不同的数据库,可以改成
<ol class="dp-c"> <li class="alt"><span><span><span><span class="string">"font-family:'sans serif', tahoma, verdana, helvetica;font-size:13px;line-height:19px;white-space:normal;background-color:#ffffff;"</span><span>> </span><span><span class="string">"font-family:'sans serif', tahoma, verdana, helvetica;white-space:normal;background-color:#ffffff;"</span><span>><!--使用A数据库的DAO--></span> <bean><span class="string">"XDao"</span><span> </span><span class="keyword">class</span><span> = </span><span class="string">"xxx.xxx.xDaoImpl"</span><span>> </span></bean></span></span></span></span></li> <li><span><property><span class="string">"sessionFactory"</span><span> ref=</span><span class="string">"sessionFactory_A"</span><span>></span></property> </span></li> <li class="alt"><span> </span></li> <li><span><!--使用B数据库的DAO--> </span></li> <li class="alt"><span><bean><span class="string">"XDao"</span><span> </span><span class="keyword">class</span><span> = </span><span class="string">"xxx.xxx.xDaoImpl"</span><span>> </span></bean></span></li> <li><span><property><span class="string">"sessionFactory"</span><span> ref=</span><span class="string">"sessionFactory_B"</span><span>></span></property> </span></li> <li class="alt"><span> </span></li> </ol>
登录后复制
这样就能实现双数据库了。。。。
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门文章
仓库:如何复兴队友
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
击败分裂小说需要多长时间?
3 周前
By DDD
Hello Kitty Island冒险:如何获得巨型种子
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前
By 尊渡假赌尊渡假赌尊渡假赌
公众号网页更新缓存难题:如何避免版本更新后旧缓存影响用户体验?
3 周前
By 王林

热门文章
仓库:如何复兴队友
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
击败分裂小说需要多长时间?
3 周前
By DDD
Hello Kitty Island冒险:如何获得巨型种子
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前
By 尊渡假赌尊渡假赌尊渡假赌
公众号网页更新缓存难题:如何避免版本更新后旧缓存影响用户体验?
3 周前
By 王林

热门文章标签

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

什么是Bitget Launchpool?如何使用Bitget Launchpool?
