Spring+Hibernate配置多数据源
来源:互联网 发布:我打打单软件 编辑:程序博客网 时间:2024/06/10 05:27
配置说明
在实际应用中,经常会用到读写分离,这里就这种情况进行Spring+Hibernate的多数据源配置。此处的配置只是让读的方法操作一个数据库,写的方法操作另外一个数据库。
注:我这里的配置JDBC连接是放在properties文件中的,当然你也可以直接写在ApplicationCpntext.xml文件中或其他的配置方式。
配置步骤
1、配置多数据库
在jdbc.Properties中,配置两个数据库的连接。在此处的例子如下(我这里都是使用的MySql,如果要使用其他的请更换驱动):
- ## MySQL local
- jdbc.driverClassName=com.mysql.jdbc.Driver
- jdbc.url= jdbc:mysql://localhost:3306/数据库名?createDatabaseIfNotExist=true&useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=convertToNull
- jdbc.username=root
- jdbc.password=root
- ## MySql Server
- jdbc_t.driverClassName=com.mysql.jdbc.Driver
- jdbc_t.url= jdbc:mysql://服务器Ip:3306/数据库名(可以和上面不一样的)?createDatabaseIfNotExist=true&useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=convertToNull
- jdbc_t.username=root
- jdbc_t.password= root
注:jdbc.driverClassName和jdbc_t.driverClassName都可以使用jdbc.driverClassName的,如果使用一个则在后面的ApplicationContext.xml中配置一样的就可以了,这里为了方便说明,分开写。同理,如果用户名和密码都一样,也可以只用一个配置就可以了。
2、配置DataSource
这里使用的是DBCP连接池。
- <!-- 使用DBCP数据库连接池进行数据源的配置 -->
- <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
- <property name="driverClassName" value="${jdbc.driverClassName}"/>
- <property name="url" value="${jdbc.url}"/>
- <property name="username" value="${jdbc.username}"/>
- <property name="password" value="${jdbc.password}"/>
- <property name="maxActive" value="100"/>
- <property name="maxWait" value="1000"/>
- <property name="poolPreparedStatements" value="true"/>
- <property name="defaultAutoCommit" value="true"/>
- <property name="removeAbandoned" value="true"/>
- <property name="logAbandoned" value="true"/>
- <property name="minEvictableIdleTimeMillis" value="10"/>
- <property name="removeAbandonedTimeout" value="5"/>
- </bean>
- <bean id="dataSource_t" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
- <property name="driverClassName" value="${jdbc_t.driverClassName}"/>
- <property name="url" value="${jdbc_t.url}"/>
- <property name="username" value="${jdbc_t.username}"/>
- <property name="password" value="${jdbc_t.password}"/>
- <property name="maxActive" value="100"/>
- <property name="maxWait" value="1000"/>
- <property name="poolPreparedStatements" value="true"/>
- <property name="defaultAutoCommit" value="true"/>
- <property name="removeAbandoned" value="true"/>
- <property name="logAbandoned" value="true"/>
- <property name="minEvictableIdleTimeMillis" value="10"/>
- <property name="removeAbandonedTimeout" value="5"/>
- </bean>
注:id不能重复,所以后面的使用了dataSource_t和dataSource以区别,这样才能区分使用的是那一个数据库。如果上面的driverClassName配置一样,你可以不用配置jdbc_t.driverClassName,都用jdbc.driverClassName即可。
3、配置sessionFactory
请注意标红加粗的地方:
- <bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
- <property name="dataSource" ref="dataSource"/>
- <property name="configLocations">
- <list>
- <value>classpath:hibernate.cfg.xml</value>
- </list>
- </property>
- <bean id="sessionFactory_t" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
- <property name="dataSource" ref="dataSource_t"/>
- <property name="configLocations">
- <list>
- <value>classpath: hibernate_t.cfg.xml</value>
- </list>
- </property>
注:hibernate.cfg.xml和hibernate_t.cfg.xml可以根据实际情况看看是否应该区别开。也可以共用一份。
4、配置DAO
在需要使用本地的数据库的时候(对于你的项目,不一定是本地),就如下配置:
<property name="sessionFactory" ref="sessionFactory" />
需要使用服务器的数据库时,如下配置:
<property name="sessionFactory" ref="sessionFactory_t" />
- spring hibernate 多数据源的配置
- Spring+Hibernate配置多数据源
- Spring+Hibernate配置多数据源
- spring 与hibernate多数据源配置
- Spring + hibernate 多数据源配置
- Spring+hibernate 配置多数据源
- Spring+Hibernate配置多数据源
- Spring+Hibernate配置多数据源
- Spring+Hibernate多数据源配置
- Spring+Hibernate配置多数据源
- Spring+Hibernate多数据源
- Hibernate 与 Spring 多数据源的配置
- Hibernate 与 Spring 多数据源的配置
- Hibernate 与 Spring 多数据源的配置
- Hibernate与Spring多数据源的配置
- Hibernate 与 Spring 多数据源的配置
- Hibernate 与 Spring 多数据源的配置
- Hibernate 与 Spring 多数据源的配置
- Spring StoredProcedure for Oracle cursor
- iPhone开发--UIActionSheet的按钮不灵敏
- 格式化输出
- poj 1436 Horizontally Visible Segments(线段树 区间的覆盖关系)
- Nginx目录设置访问验证
- Spring+Hibernate配置多数据源
- 【Matlab】数据降维工具箱drtoolbox
- INF SourceDisksNames Section 和 SourceDisksFiles Section详解
- Linux 学习笔记
- 348 - Optimal Array Multiplication Sequence
- http发送get请求的总结
- ScrollView或者ListView中嵌套ViewPager,展示不出来问题。
- cvSVD(&A, &U, &S, &V, CV_SVD_U_T);
- 分享一个java写的简单计算器