Spring-data-jpa操做數據庫環境配置

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>
相關文章
相關標籤/搜索