广告位联系
返回顶部
分享到

springmvc+Hibernate+JPA(混合事务)的介绍

java 来源:互联网 作者:佚名 发布时间:2024-09-27 21:53:51 人浏览
摘要

springmvc+Hibernate+JPA(混合事务) 最近发觉 spring-data-jpa 比较好用。 我在springcloud的项目中使用后,也尝试在springmvc中增加 jpa。 但是老项目用的是hibernate,在使用添加jpa后,事务出现了一些问题。

springmvc+Hibernate+JPA(混合事务)

最近发觉 spring-data-jpa 比较好用。

我在springcloud的项目中使用后,也尝试在springmvc中增加 jpa。

但是老项目用的是hibernate,在使用添加jpa后,事务出现了一些问题。

解决方案

配置文件

1 配置Hibernate事务(transactionManager)

1

2

3

4

5

6

<!-- 事物管理器配置  -->

    <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事务(transactionManager_jpa)

1

2

3

4

5

6

7

8

9

10

<!-- Jpa 事务配置 -->

    <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定义事务 -->

    <tx:annotation-driven transaction-manager="transactionManager_jpa" proxy-target-class="true" />

配置全本:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

<?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">

 

    <!--配置数据源-->

    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">

        <property name="driverClass" value="${jdbc.driver}" />  <!--数据库连接驱动-->

        <property name="jdbcUrl" value="${jdbc.jdbcUrl}" />     <!--数据库地址-->

        <property name="user" value="${jdbc.user}" />   <!--用户名-->

        <property name="password" value="${jdbc.password}" />   <!--密码-->

        <property name="maxPoolSize" value="${jdbc.maxPoolSize}" />      <!--最大连接数-->

        <property name="minPoolSize" value="${jdbc.miniPoolSize}" />       <!--最小连接数-->

        <property name="initialPoolSize" value="${jdbc.initialPoolSize}" />      <!--初始化连接池内的数据库连接-->

        <property name="maxIdleTime" value="${jdbc.maxIdleTime}" />  <!--最大空闲时间-->

    </bean>

 

    <!--  hibernate  -->

    <!--配置session工厂-->

    <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根据实体自动生成数据库表-->

                <prop key="hibernate.dialect">${hibernate.dialect}</prop>   <!--指定数据库方言-->

                <prop key="hibernate.show_sql">${hibernate.show_sql}</prop>     <!--在控制台显示执行的数据库操作语句-->

                <prop key="hibernate.format_sql">${hibernate.format_sql}</prop>     <!--在控制台显示执行的数据哭操作语句(格式)-->

                <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>  <!-- 查询缓存 -->

                <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实体管理器工厂 -->

    <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>

 

                <!-- 建表的命名规则 -->

                <prop key="hibernate.ejb.naming_strategy">org.hibernate.cfg.ImprovedNamingStrategy</prop>

 

            </props>

        </property>

    </bean>

 

    <!-- 设置JPA实现厂商的特定属性 -->

    <bean id="hibernateJpaVendorAdapter"

          class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">

        <property name="databasePlatform" value="${hibernate.dialect}"/>

    </bean>

 

    <!-- Jpa 事务配置 -->

    <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定义事务 -->

    <tx:annotation-driven transaction-manager="transactionManager_jpa" proxy-target-class="true" />

    <!--  JPA  -->

 

</beans>

修改@Transactional

在使用JPA时,注明

@Transactional("transactionManager_jpa")

1

2

3

4

5

6

7

@Transactional("transactionManager_jpa")

    @Override

    public Model_Res add(Model_Req req) {

        //jpa dao

        Model entity = dao.save(reqData);

        return res;

    }

原来的Hibernate不用改变(因为)


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。
原文链接 :
相关文章
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计