欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

springmvc+Hibernate+JPA(混合事務(wù))解讀

 更新時(shí)間:2024年09月27日 15:34:51   作者:正怒月神  
在Spring項(xiàng)目中,Spring Data JPA作為一種持久層框架,因其簡(jiǎn)化數(shù)據(jù)庫(kù)操作而受到青睞,但在將其引入使用Hibernate的舊項(xiàng)目時(shí),可能會(huì)遇到事務(wù)處理問(wèn)題,解決方案包括配置兩種事務(wù)管理器:Hibernate事務(wù)管理器和JPA事務(wù)管理器

springmvc+Hibernate+JPA(混合事務(wù))

最近發(fā)覺(jué) spring-data-jpa 比較好用。

我在springcloud的項(xiàng)目中使用后,也嘗試在springmvc中增加 jpa。

但是老項(xiàng)目用的是hibernate,在使用添加jpa后,事務(wù)出現(xiàn)了一些問(wèn)題。

解決方案

配置文件

1 配置Hibernate事務(wù)(transactionManager)

    <!-- 事物管理器配置  -->
        <bean id="transactionManager" class="org.springframework.orm.hibernate5.HibernateTransactionManager">
            <property name="sessionFactory" ref="sessionFactory" />
        </bean>
        <tx:annotation-driven transaction-manager="transactionManager" proxy-target-class="true" />
    <!--  hibernate  -->

2 配置Jpa事務(wù)(transactionManager_jpa)

<!-- Jpa 事務(wù)配置 -->
    <bean id="transactionManager_jpa" class="org.springframework.orm.jpa.JpaTransactionManager">
        <property name="entityManagerFactory" ref="entityManagerFactory"/>
    </bean>

    <!-- Spring Data Jpa配置 -->
    <jpa:repositories base-package="com.kintech.dao.*"  transaction-manager-ref="transactionManager_jpa" entity-manager-factory-ref="entityManagerFactory"/>

    <!-- 使用annotation定義事務(wù) -->
    <tx:annotation-driven transaction-manager="transactionManager_jpa" proxy-target-class="true" />

配置全本:

<?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"
       xmlns:mvc="http://www.springframework.org/schema/mvc"
       xmlns:aop="http://www.springframework.org/schema/aop"
       xmlns:tx="http://www.springframework.org/schema/tx"
       xmlns:p="http://www.springframework.org/schema/p" 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.3.xsd
                           http://www.springframework.org/schema/context
                           http://www.springframework.org/schema/context/spring-context-4.3.xsd
                           http://www.springframework.org/schema/mvc
                           http://www.springframework.org/schema/mvc/spring-mvc-4.3.xsd
                           http://www.springframework.org/schema/aop
						   http://www.springframework.org/schema/aop/spring-aop-4.3.xsd
						   http://www.springframework.org/schema/tx
                           http://www.springframework.org/schema/tx/spring-tx-4.3.xsd http://www.springframework.org/schema/data/jpa http://www.springframework.org/schema/data/jpa/spring-jpa.xsd"
       default-lazy-init="true">

    <!--配置數(shù)據(jù)源-->
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
        <property name="driverClass" value="${jdbc.driver}" />  <!--數(shù)據(jù)庫(kù)連接驅(qū)動(dòng)-->
        <property name="jdbcUrl" value="${jdbc.jdbcUrl}" />     <!--數(shù)據(jù)庫(kù)地址-->
        <property name="user" value="${jdbc.user}" />   <!--用戶(hù)名-->
        <property name="password" value="${jdbc.password}" />   <!--密碼-->
        <property name="maxPoolSize" value="${jdbc.maxPoolSize}" />      <!--最大連接數(shù)-->
        <property name="minPoolSize" value="${jdbc.miniPoolSize}" />       <!--最小連接數(shù)-->
        <property name="initialPoolSize" value="${jdbc.initialPoolSize}" />      <!--初始化連接池內(nèi)的數(shù)據(jù)庫(kù)連接-->
        <property name="maxIdleTime" value="${jdbc.maxIdleTime}" />  <!--最大空閑時(shí)間-->
    </bean>

    <!--  hibernate  -->
    <!--配置session工廠(chǎng)-->
    <bean id="sessionFactory" class="org.springframework.orm.hibernate5.LocalSessionFactoryBean">
        <property name="dataSource" ref="dataSource" />
        <property name="packagesToScan" value="com.kintech.model" />
        <property name="hibernateProperties">
            <props>
                <prop key="hibernate.hbm2ddl.auto">${hibernate.hbm2ddl.auto}</prop> <!--hibernate根據(jù)實(shí)體自動(dòng)生成數(shù)據(jù)庫(kù)表-->
                <prop key="hibernate.dialect">${hibernate.dialect}</prop>   <!--指定數(shù)據(jù)庫(kù)方言-->
                <prop key="hibernate.show_sql">${hibernate.show_sql}</prop>     <!--在控制臺(tái)顯示執(zhí)行的數(shù)據(jù)庫(kù)操作語(yǔ)句-->
                <prop key="hibernate.format_sql">${hibernate.format_sql}</prop>     <!--在控制臺(tái)顯示執(zhí)行的數(shù)據(jù)哭操作語(yǔ)句(格式)-->
                <prop key="hibernate.cache.use_second_level_cache">${hibernate.cache.use_second_level_cache}</prop>
                <prop key="hibernate.cache.use_query_cache">${hibernate.cache.use_query_cache}</prop>  <!-- 查詢(xún)緩存 -->
                <prop key="hibernate.cache.provider_class">${hibernate.cache.provider_class}</prop>
                <prop key="hibernate.cache.region.factory_class">${hibernate.cache.region.factory_class}</prop>
            </props>
        </property>
    </bean>
    <!-- 事物管理器配置  -->
        <bean id="transactionManager" class="org.springframework.orm.hibernate5.HibernateTransactionManager">
            <property name="sessionFactory" ref="sessionFactory" />
        </bean>
        <tx:annotation-driven transaction-manager="transactionManager" proxy-target-class="true" />
    <!--  hibernate  -->

    <!--  JPA  -->
    <!-- JPA實(shí)體管理器工廠(chǎng) -->
    <bean id="entityManagerFactory" name="jpaEntityManagerFactory"
          class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
        <property name="dataSource" ref="dataSource" />
        <property name="jpaVendorAdapter" ref="hibernateJpaVendorAdapter" />
        <!-- 加入定制化包路徑 -->
        <property name="packagesToScan" value="com.kintech.model.domain.*" />

        <property name="jpaProperties">
            <props>
                <prop key="hibernate.current_session_context_class">thread</prop>
                <prop key="hibernate.hbm2ddl.auto">none</prop><!-- validate/update/create -->
                <prop key="hibernate.show_sql">true</prop>
                <prop key="hibernate.format_sql">true</prop>

                <!-- 建表的命名規(guī)則 -->
                <prop key="hibernate.ejb.naming_strategy">org.hibernate.cfg.ImprovedNamingStrategy</prop>

            </props>
        </property>
    </bean>

    <!-- 設(shè)置JPA實(shí)現(xiàn)廠(chǎng)商的特定屬性 -->
    <bean id="hibernateJpaVendorAdapter"
          class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
        <property name="databasePlatform" value="${hibernate.dialect}"/>
    </bean>

    <!-- Jpa 事務(wù)配置 -->
    <bean id="transactionManager_jpa" class="org.springframework.orm.jpa.JpaTransactionManager">
        <property name="entityManagerFactory" ref="entityManagerFactory"/>
    </bean>

    <!-- Spring Data Jpa配置 -->
    <jpa:repositories base-package="com.kintech.dao.*"  transaction-manager-ref="transactionManager_jpa" entity-manager-factory-ref="entityManagerFactory"/>

    <!-- 使用annotation定義事務(wù) -->
    <tx:annotation-driven transaction-manager="transactionManager_jpa" proxy-target-class="true" />
    <!--  JPA  -->

</beans>

修改@Transactional

在使用JPA時(shí),注明

@Transactional("transactionManager_jpa")

@Transactional("transactionManager_jpa")
    @Override
    public Model_Res add(Model_Req req) {
        //jpa dao
        Model entity = dao.save(reqData);
        return res;
    }

原來(lái)的Hibernate不用改變(因?yàn)?

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • idea2017建立jsp工程及tomcat配置教程

    idea2017建立jsp工程及tomcat配置教程

    本文通過(guò)圖文并茂的形式給大家介紹了idea2017建立jsp工程及tomcat等配置的方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2018-02-02
  • 詳解如何在Java中創(chuàng)建Excel迷你圖

    詳解如何在Java中創(chuàng)建Excel迷你圖

    迷你圖是一種簡(jiǎn)潔而有效的數(shù)據(jù)可視化方式,常用于展示趨勢(shì)和變化,通常被用于數(shù)據(jù)儀表盤(pán)、報(bào)告和展示中,以便在有限的空間內(nèi)展示多個(gè)數(shù)據(jù)集的趨勢(shì),今天小編為大家介紹如何在Java中創(chuàng)建Excel迷你圖,需要的朋友可以參考下
    2023-10-10
  • Java踩坑記錄之Arrays.AsList

    Java踩坑記錄之Arrays.AsList

    這篇文章主要給大家介紹了關(guān)于Java踩坑記錄之Arrays.AsList的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • Java排序之冒泡排序的實(shí)現(xiàn)與優(yōu)化

    Java排序之冒泡排序的實(shí)現(xiàn)與優(yōu)化

    冒泡排序是一種簡(jiǎn)單的交換排序。之所以叫做冒泡排序,因?yàn)槲覀兛梢园衙總€(gè)元素當(dāng)成一個(gè)小氣泡,根據(jù)氣泡大小,一步一步移動(dòng)到隊(duì)伍的一端,最后形成一定對(duì)的順序。本文將利用Java實(shí)現(xiàn)冒泡排序,并進(jìn)行一定的優(yōu)化,希望對(duì)大家有所幫助
    2022-11-11
  • Spring三級(jí)緩存思想解決循環(huán)依賴(lài)總結(jié)分析

    Spring三級(jí)緩存思想解決循環(huán)依賴(lài)總結(jié)分析

    這篇文章主要為大家介紹了Spring三級(jí)緩存思想解決循環(huán)依賴(lài)總結(jié)分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • hadoop運(yùn)行java程序(jar包)并運(yùn)行時(shí)動(dòng)態(tài)指定參數(shù)

    hadoop運(yùn)行java程序(jar包)并運(yùn)行時(shí)動(dòng)態(tài)指定參數(shù)

    這篇文章主要介紹了hadoop如何運(yùn)行java程序(jar包)并運(yùn)行時(shí)動(dòng)態(tài)指定參數(shù),使用hadoop 運(yùn)行 java jar包,Main函數(shù)一定要加上全限定類(lèi)名,需要的朋友可以參考下
    2021-06-06
  • Mybatis中如何設(shè)置sqlSession自動(dòng)提交

    Mybatis中如何設(shè)置sqlSession自動(dòng)提交

    在MyBatis中,默認(rèn)情況下,獲取的SqlSession對(duì)象不會(huì)自動(dòng)提交事務(wù),這意味著在進(jìn)行更新、刪除或插入等操作后,需要顯式調(diào)用commit方法來(lái)提交事務(wù),但是,可以在獲取SqlSession時(shí)通過(guò)將openSession方法的參數(shù)設(shè)置為true
    2024-09-09
  • Java設(shè)計(jì)模式之策略模式的使用(Strategy?Pattern)

    Java設(shè)計(jì)模式之策略模式的使用(Strategy?Pattern)

    策略模式是一種行為型設(shè)計(jì)模式,用于定義一系列算法并將每個(gè)算法封裝起來(lái),使它們可以互相替換,從而實(shí)現(xiàn)代碼的可維護(hù)性和靈活性,策略模式包含策略接口、具體策略類(lèi)和上下文類(lèi),并通過(guò)將算法的選擇與使用分離,使得算法可以獨(dú)立變化
    2025-03-03
  • Java數(shù)據(jù)結(jié)構(gòu)與算法之二分查找詳解

    Java數(shù)據(jù)結(jié)構(gòu)與算法之二分查找詳解

    這篇文章主要介紹了Java數(shù)據(jù)結(jié)構(gòu)與算法之二分查找詳解,二分查找算法是一種在有序數(shù)組中查找某一特定元素的搜索算法,其思想就是不斷地將有序查找表“一分為二”,逐漸縮小搜索區(qū)域,進(jìn)而找到目標(biāo)元素,需要的朋友可以參考下
    2023-12-12
  • 使用Java實(shí)現(xiàn)文件夾的遍歷操作指南

    使用Java實(shí)現(xiàn)文件夾的遍歷操作指南

    網(wǎng)上大多采用java遞歸的方式遍歷文件夾下的文件,這里我不太喜歡遞歸的風(fēng)格,這篇文章主要給大家介紹了關(guān)于使用Java實(shí)現(xiàn)文件夾的遍歷操作的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-05-05

最新評(píng)論