接上一个博文,没有数据库连接池,纯粹用jpa的官方链接。
所以这次要加上连接池本文用Druid连接池来实现多数据源的配置。
persistence.xml 这个文件可以省略了,全部配置在applicationContext.xml 里面:
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop" xmlns:context="http://www.springframework.org/schema/context" xmlns:jpa="http://www.springframework.org/schema/data/jpa" xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:tx="http://www.springframework.org/schema/tx" xmlns:util="http://www.springframework.org/schema/util" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.1.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.1.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.1.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.1.xsd http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-4.1.xsd http://www.springframework.org/schema/data/jpa http://www.springframework.org/schema/data/jpa/spring-jpa-1.2.xsd"> <context:annotation-config/> <context:component-scan base-package="com.tw"/> <!-- mysql数据源配置 --> <bean id="mysqlDataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close"> <!-- 驱动名称 --> <property name="DriverClassName" value="com.mysql.jdbc.Driver" /> <!-- JDBC连接串 --> <property name="url" value="jdbc:mysql://192.168.132.1:3306/twq?useUnicode=true&characterEncoding=UTF-8" /> <!-- 数据库用户名称 --> <property name="username" value="ws" /> <!-- 数据库密码 --> <property name="password" value="unionmanws" /> <!-- 连接池最大使用连接数量 --> <property name="maxActive" value="20" /> <!-- 初始化大小 --> <property name="initialSize" value="5" /> <!-- 获取连接最大等待时间 --> <property name="maxWait" value="60000" /> <!-- 连接池最小空闲 --> <property name="minIdle" value="2" /> <!-- 逐出连接的检测时间间隔 --> <property name="timeBetweenEvictionRunsMillis" value="3000" /> <!-- 最小逐出时间 --> <property name="minEvictableIdleTimeMillis" value="300000" /> <!-- 测试有效用的SQL Query --> <property name="validationQuery" value="SELECT 'x'" /> <!-- 连接空闲时测试是否有效 --> <property name="testWhileIdle" value="true" /> <!-- 获取连接时测试是否有效 --> <property name="testOnBorrow" value="false" /> <!-- 归还连接时是否测试有效 --> <property name="testOnReturn" value="false" /> </bean> <!-- 整合mysqljpa --> <bean id="mysqlEntityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"> <property name="dataSource" ref="mysqlDataSource"></property> <property name="packagesToScan" value="com.tw.entity.sys"></property> <property name="persistenceUnitName" value="mysqldb"></property> <property name="jpaVendorAdapter"> <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"> <property name="showSql" value="true"></property> </bean> </property> <property name="jpaProperties"> <props> <!--设置外连接抓取树的最大深度 --> <prop key="hibernate.max_fetch_depth">3</prop> <prop key="hibernate.jdbc.fetch_size">18</prop> <prop key="hibernate.jdbc.batch_size">10</prop> <!-- 自动建表类型 validate|create|create-drop|update --> <!-- <prop key="hibernate.hbm2ddl.auto">validate</prop> --> <!-- 是否显示SQL --> <prop key="hibernate.show_sql">false</prop> <!-- 显示SQL是否格式化 --> <prop key="hibernate.format_sql">false</prop> <!-- 关闭二级缓存 --> <prop key="hibernate.cache.provider_class">org.hibernate.cache.NoCacheProvider</prop> <!-- 关闭实体字段映射校验 --> <prop key="javax.persistence.validation.mode">none</prop> </props> </property> </bean> <bean id="mysqltransactionManager" class="org.springframework.orm.jpa.JpaTransactionManager"> <property name="entityManagerFactory" ref="mysqlEntityManagerFactory" /> <qualifier value="mysqlEM"/> </bean> <tx:annotation-driven transaction-manager="mysqltransactionManager" proxy-target-class="false"/> <!-- sqlserver数据源配置 --> <bean id="sqlserverDataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close"> <!-- 驱动名称 --> <property name="DriverClassName" value="com.microsoft.sqlserver.jdbc.SQLServerDriver" /> <!-- JDBC连接串 --> <property name="url" value="jdbc:sqlserver://192.168.130.10:1433;DatabaseName=unionman" /> <!-- 数据库用户名称 --> <property name="username" value="sa" /> <!-- 数据库密码 --> <property name="password" value="123abc" /> <!-- 连接池最大使用连接数量 --> <property name="maxActive" value="20" /> <!-- 初始化大小 --> <property name="initialSize" value="5" /> <!-- 获取连接最大等待时间 --> <property name="maxWait" value="60000" /> <!-- 连接池最小空闲 --> <property name="minIdle" value="2" /> <!-- 逐出连接的检测时间间隔 --> <property name="timeBetweenEvictionRunsMillis" value="3000" /> <!-- 最小逐出时间 --> <property name="minEvictableIdleTimeMillis" value="300000" /> <!-- 测试有效用的SQL Query --> <property name="validationQuery" value="SELECT 'x'" /> <!-- 连接空闲时测试是否有效 --> <property name="testWhileIdle" value="true" /> <!-- 获取连接时测试是否有效 --> <property name="testOnBorrow" value="false" /> <!-- 归还连接时是否测试有效 --> <property name="testOnReturn" value="false" /> </bean> <!-- 整合sqlserverjpa --> <bean id="sqlserverEntityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"> <property name="dataSource" ref="sqlserverDataSource"></property> <property name="packagesToScan" value="com.tw.entity.plan"></property> <property name="persistenceUnitName" value="sqlserverdb"></property> <property name="jpaVendorAdapter"> <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"> <property name="showSql" value="true"></property> </bean> </property> <property name="jpaProperties"> <props> <!--设置外连接抓取树的最大深度 --> <prop key="hibernate.max_fetch_depth">3</prop> <prop key="hibernate.jdbc.fetch_size">18</prop> <prop key="hibernate.jdbc.batch_size">10</prop> <!-- 自动建表类型 validate|create|create-drop|update --> <!-- <prop key="hibernate.hbm2ddl.auto">validate</prop> --> <!-- 是否显示SQL --> <prop key="hibernate.show_sql">false</prop> <!-- 显示SQL是否格式化 --> <prop key="hibernate.format_sql">false</prop> <!-- 关闭二级缓存 --> <prop key="hibernate.cache.provider_class">org.hibernate.cache.NoCacheProvider</prop> <!-- 关闭实体字段映射校验 --> <prop key="javax.persistence.validation.mode">none</prop> </props> </property> </bean> <bean id="sqlservertransactionManager" class="org.springframework.orm.jpa.JpaTransactionManager"> <property name="entityManagerFactory" ref="sqlserverEntityManagerFactory" /> <qualifier value="sqlserverEM"/> </bean> <tx:annotation-driven transaction-manager="sqlservertransactionManager" proxy-target-class="false"/> </beans>
其他地方按上次的配置不需要做改动。这样就好了。
文章转载自:www.loveweir.com
相关推荐
实现了spring3+springmvc+jpa2.0之间的集成,采用多数据源实现jpa,本例子提供的数据源为hibernate何datastore,为需要的朋友省去搭建框架的时间
spring4.2+spring mvc +spring data+jpa+hibernate的程序构架
Spring Boot+Jpa多数据源配置Demo,可同时支持多种数据库,不同数据库,同时支持不同数据库的JdbcTemplate
springMVC+spring+hibernate+jquery分页完整项目,完整代码
Maven整合Spring+SpringMVC+Hibernate+SpringDataJPA
spring+springmvc+hibernate+jpa环境搭建
实现了spring3+springmvc+jpa2.0+hibernate之间的集成,框架搭建。项目可以直接在tomcat中运行
这案例是spring boot+druid+jpa(hibernate)+mysql搭建的maven结构的基础案例
资源中示例运用sts搭建的spring boot项目,集成mysql+druid+redis+jpa+ajax,实现了CRUD功能,遗留问题:控制层返回一个ModelAndView(或者Model),在.html页面中用EL表达式无法展示对应数据
Spring+SpringMVC+SpringData+JPA+hibernate+shiro完美整合,你需要的包都在这了
spring4.0.1 springMVC jpa2.0 hibernate4.3.7 框架整合
这是jsf+spring2.5+jpa(hibernate)的jar包,很多人为了jsj环境而配置半天,在此提供jar包共享。注:除了ajax4jsf和tomahawk-1.1.3.jar,因为csdn只让我上传20mb,大家自己可以下一下自己试试。
IDEA + SpringBoot + SpringSecurity + JPA 实现用户角色权限登录认证,security过滤请求资源,用户登录获取用户角色权限,过滤用户非法请求等
持久层框架:Spring boot Jpa 安全框架:Spring Security 缓存框架:Redis 日志打印:logback+log4jdbc 接口文档 swagger2 其他:fastjson,aop,MapStruct等。 页面框架:Vue 前端源码:eladmin-qt 后端源码:el...
基础框架,可满足开发需要
移除Druid和多数据源 TODO 链式调用,尽量去掉显示调用subscribe(分支rm-subscribe) 使用 启动MySQL 默认账号 root root(或者修改application.properties) 创建数据库 managesystemdb 启动Redis 默认配置 系统...
Spring Boot使用spring-data-jpa配置Mysql多数据源,可用版本
Flex 是一个高效、免费的开源框架,可用于构建具有表现力的 Web应用程序,这些应用... 本课程主要是讲解Flex 4.6和ActionScript 3.0使用方法和技巧,并结合BlazDS/Spring /JPA/Hibernate等技术实现在线书店的开发过程。
免费的Spring++JPA+Hibernate搭建,手把手教你如何搭建SpringMVC+Hibernate框架
自己学习spring4+hibernate4+jpa 写的一个demo 附有jar包 和大家分享一下 不足之处希望大家多多指教