application.xml文件html
<?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:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-4.2.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-4.2.xsd">
<context:property-placeholder location="classpath*:properties/*.properties"/> //數據庫鏈接參數
<context:component-scan base-package="com.jerry.service"/> //設置自動掃描service包
<context:annotation-config/>
</beans>
applicationContext-dataSource.xml 設置數據庫鏈接屬性java
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-4.2.xsd">
<!--上面的xsd最好和當前使用的Spring版本號一致,若是換了Spring版本,這個最好也跟着改-->
<!-- 使用阿里的druid配置數據源 start-->
<!--具體查看官網信息:https://github.com/alibaba/druid/wiki/%E9%85%8D%E7%BD%AE_DruidDataSource%E5%8F%82%E8%80%83%E9%85%8D%E7%BD%AE-->
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">
<!--這三個變量讀取config.properties的-->
<property name="url" value="${data_source_url}"/>
<property name="username" value="${data_source_username}"/>
<property name="password" value="${data_source_password}"/>
<!-- 初始化鏈接大小 -->
<property name="initialSize" value="1"/>
<!-- 初始化鏈接池最大使用鏈接數量 -->
<property name="maxActive" value="20"/>
<!-- 初始化鏈接池最小空閒 -->
<property name="minIdle" value="1"/>
<!-- 獲取鏈接最大等待時間,單位毫秒-->
<property name="maxWait" value="60000"/>
<!-- 配置間隔多久才進行一次檢測,檢測須要關閉的空閒鏈接,單位是毫秒 -->
<property name="timeBetweenEvictionRunsMillis" value="60000"/>
<!-- 配置一個鏈接在池中最小生存的時間,單位是毫秒 -->
<property name="minEvictableIdleTimeMillis" value="25200000"/>
<!-- 打開PSCache,而且指定每一個鏈接上PSCache的大小 -->
<!--若是用Oracle,則把poolPreparedStatements配置爲true,mysql能夠配置爲false。分庫分表較多的數據庫,建議配置爲false。-->
<property name="poolPreparedStatements" value="false" />
<property name="maxPoolPreparedStatementPerConnectionSize" value="20" />
<property name="validationQuery" value="${validation_query}"/>
<property name="testWhileIdle" value="true"/>
<property name="testOnBorrow" value="false"/>
<property name="testOnReturn" value="false"/>
<!--當程序存在缺陷時,申請的鏈接忘記關閉,這時候,就存在鏈接泄漏了。Druid提供了RemoveAbandanded相關配置,用來關閉長時間不使用的鏈接-->
<!--配置removeAbandoned對性能會有一些影響,建議懷疑存在泄漏以後再打開。在上面的配置中,若是鏈接超過30分鐘未關閉,就會被強行回收,而且日誌記錄鏈接申請時的調用堆棧。-->
<!--具體查看官網信息:https://github.com/alibaba/druid/wiki/%E8%BF%9E%E6%8E%A5%E6%B3%84%E6%BC%8F%E7%9B%91%E6%B5%8B-->
<!-- 打開removeAbandoned功能 -->
<property name="removeAbandoned" value="true"/>
<!-- 1800秒,也就是30分鐘 -->
<property name="removeAbandonedTimeout" value="1800"/>
<!-- 關閉abanded鏈接時輸出錯誤日誌 -->
<property name="logAbandoned" value="true"/>
<!-- 配置監控統計攔截的filters-->
<!--官網信息:https://github.com/alibaba/druid/wiki/%E9%85%8D%E7%BD%AE_StatFilter-->
<!--mergeSql能夠合併輸出的sql,方便查看,可是在mybatis框架中使用這個則沒法監控sql,須要用stat-->
<!--<property name="filters" value="mergeSql,log4j"/>-->
<!--<property name="filters" value="mergeSql,wall"/>-->
<!--<property name="filters" value="stat"/>-->
<!--<property name="filters" value="mergeSql"/>-->
<property name="filters" value="stat,log4j"/>
</bean>
<!-- 使用阿里的druid配置數據源 end-->
</beans>
applicationContext-jpa.xmlmysql
<?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:jpa="http://www.springframework.org/schema/data/jpa"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-4.2.xsd
http://www.springframework.org/schema/data/jpa
http://www.springframework.org/schema/data/jpa/spring-jpa.xsd">
<!--上面的xsd最好和當前使用的Spring版本號一致,若是換了Spring版本,這個最好也跟着改-->
<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
<property name="persistenceUnitName" value="Jerry"/>
<property name="persistenceXmlLocation" value="classpath*:META-INF/persistence.xml"></property> //persistence.xml文件配置(不展現)
<property name="dataSource" ref="dataSource"/>
<!--zchtodo 這個做用是什麼?-->
<property name="jpaDialect">
<bean class="org.springframework.orm.jpa.vendor.HibernateJpaDialect"/>
</property>
<!-- 指定Jpa持久化實現廠商類,這裏以Hibernate爲例 -->
<property name="jpaVendorAdapter" ref="hibernateJpaVendorAdapter"/>
<!-- 指定Entity實體類包路徑 -->
<property name="packagesToScan">
<list>
<value>com.jerry.entity</value>
</list>
</property>
<!-- 指定JPA屬性;如Hibernate中指定是否顯示SQL的是否顯示、方言等 -->
<property name="jpaProperties">
<!--hibernate 官網說明這些配置屬性:http://docs.jboss.org/hibernate/orm/3.3/reference/en/html/session-configuration.html-->
<props>
<!--常見的還有 MySQL5Dialect、MySQL5InnoDBDialect、MySQL57InnoDBDialect、MySQLDialect、MySQLInnoDBDialect、MySQLMyISAMDialect-->
<!--若是你使用的數據庫是 5.7 的話能夠考慮用:MySQL57InnoDBDialect-->
<prop key="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</prop>
<!--是否顯示 SQL-->
<prop key="hibernate.show_sql">true</prop>
<!--若是顯示 SQL,輸出的 SQL 時候要格式化-->
<prop key="hibernate.format_sql">true</prop>
<!--在顯示的 SQL 中增長一些 Hibernate 提供的註釋說明,依此來解釋它生成的 SQL 意思-->
<!--配置如何根據java模型生成數據庫表結構,經常使用update,validate-->
<prop key="hibernate.use_sql_comments">true</prop>
<prop key="hibernate.hbm2ddl.auto">none</prop>
<!--關於這個屬性能夠看:http://blog.csdn.net/dracotianlong/article/details/27834143-->
<!--ImprovedNamingStrategy 是採用下劃線,符合咱們通常命名錶字段的習慣-->
<!--因此,命名規則 My_NAME->MyName-->
<prop key="hibernate.ejb.naming_strategy">org.hibernate.cfg.ImprovedNamingStrategy</prop>
<prop key="hibernate.generate_statistics">false</prop>
</props>
</property>
</bean>
<!-- Hibernate對Jpa的實現 -->
<bean id="hibernateJpaVendorAdapter" class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"/>
<!-- 重要配置:啓用掃描並自動建立代理的功能 -->
<jpa:repositories base-package="com.jerry.reposity" transaction-manager-ref="transactionManager" entity-manager-factory-ref="entityManagerFactory"/>
</beans>
applicationContext-transaction.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:tx="http://www.springframework.org/schema/tx" xmlns:aop="http://www.springframework.org/schema/aop" xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans-4.2.xsdhttp://www.springframework.org/schema/txhttp://www.springframework.org/schema/tx/spring-tx-4.2.xsdhttp://www.springframework.org/schema/aophttp://www.springframework.org/schema/aop/spring-aop-4.2.xsd"> <bean id="druid-stat-interceptor" class="com.alibaba.druid.support.spring.stat.DruidStatInterceptor" /> <bean id="druid-stat-pointcut" class="org.springframework.aop.support.JdkRegexpMethodPointcut" scope="prototype"> <property name="patterns"> <list> <value>com.youmeek.ssm.module.*.service.*</value> </list> </property> </bean> <aop:config proxy-target-class="true"> <aop:advisor advice-ref="druid-stat-interceptor" pointcut-ref="druid-stat-pointcut" /> </aop:config> <!-- Druid 和 Spring 關聯監控配置 end--> <!-- 事務管理器 --> <bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager" > <property name="entityManagerFactory" ref="entityManagerFactory" /> </bean> <!-- 啓用註解方式1:開啓註解事務 start--> <!--<tx:annotation-driven transaction-manager="transactionManager" proxy-target-class="true" />--> <!-- 啓用註解方式1:開啓註解事務 end--> <!-- 啓用註解方式2:開啓AOP事務方式 start--> <tx:advice id="transactionAdvice" transaction-manager="transactionManager"> <tx:attributes> <!--REQUIRED 表示:支持當前事務,若是當前沒有事務,就新建一個事務。這是最多見的選擇。--> <tx:method name="save*" propagation="REQUIRED"/> <tx:method name="insert*" propagation="REQUIRED"/> <tx:method name="add*" propagation="REQUIRED"/> <tx:method name="register*" propagation="REQUIRED"/> <tx:method name="update*" propagation="REQUIRED"/> <tx:method name="modify*" propagation="REQUIRED"/> <tx:method name="edit*" propagation="REQUIRED"/> <tx:method name="batch*" propagation="REQUIRED"/> <tx:method name="delete*" propagation="REQUIRED"/> <tx:method name="del*" propagation="REQUIRED"/> <tx:method name="deleteAndRepair" propagation="REQUIRED"/> <tx:method name="remove*" propagation="REQUIRED"/> <tx:method name="time*" propagation="REQUIRED"/><!--定時器方法--> <tx:method name="repair" propagation="REQUIRED"/> <!--以這些單詞開頭的方法不加入事務--> <!--SUPPORTS 表示:支持當前事務,若是當前沒有事務,就以非事務方式執行。--> <tx:method name="get*" propagation="SUPPORTS" read-only="true"/> <tx:method name="find*" propagation="SUPPORTS" read-only="true"/> <tx:method name="select*" propagation="SUPPORTS" read-only="true"/> <tx:method name="load*" propagation="SUPPORTS" read-only="true"/> <tx:method name="search*" propagation="SUPPORTS" read-only="true"/> <tx:method name="datagrid*" propagation="SUPPORTS" read-only="true"/> <tx:method name="show*" propagation="SUPPORTS" read-only="true"/> </tx:attributes> </tx:advice> <aop:config> <aop:pointcut id="transactionPointcut" expression="execution(* com.jerry.service.impl.*.*(..) )"/> <aop:advisor pointcut-ref="transactionPointcut" advice-ref="transactionAdvice"/> </aop:config> <!-- 啓用註解方式2:開啓AOP事務方式 end--></beans>