gpt4 book ai didi

hibernate - Spring 的自动 hibernate 事务管理?

转载 作者:IT老高 更新时间:2023-10-28 13:45:47 25 4
gpt4 key购买 nike

Spring 框架在事务处理方面走了多远?我对“Spring In Action”一书的阅读建议您创建不用担心 session 和事务管理的 DAO 方法,只需在 XML 中设置 session 工厂和事务模板,然后将它们连接到您的 DAO。另一方面,SpringSource.org 的文档表明需要大量的 XML 和/或注释来实现这一点。

这里的真相是什么,我可以按照以下方式编写代码的最简单方法是什么

get session from sessionfactory
open transaction
preform database actions
commit transaction with error handling

让它变得简单

preform database actions

将我在我的方法中拥有的样板事务代码的数量减少到最低限度?

最佳答案

您应该做一些工作才能做到这一点,但根本不是很多。假设,您将使用 JPA 来选择您自己的提供程序,例如 hibernate 。然后你需要将定义持久化单元的persistence.xml放在META-INF文件夹中:

<?xml version="1.0" encoding="UTF-8"?>
<persistence xmlns="http://java.sun.com/xml/ns/persistence"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd"
version="1.0">
<persistence-unit name="YourDatabasePersistenceUnitName" transaction-type="RESOURCE_LOCAL"/>
</persistence>

接下来,在您使用的 Spring 应用程序上下文中定义数据库连接所需的一切,至少应包含以下内容:

<bean id="propertyConfigurer"
class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="locations">
<list>
<value>/WEB-INF/jdbc.properties</value>
</property>
</bean>

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
destroy-method="close" scope="singleton">
<property name="driverClassName" value="org.postgresql.Driver"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
</bean>

<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
<property name="persistenceUnitName" value="YourDatabasePersistenceUnitName"/>
<property name="dataSource" ref="dataSource"/>
<property name="jpaVendorAdapter">
<bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
<property name="database" value="POSTGRESQL" />
<property name="databasePlatform" value="org.hibernate.dialect.PostgreSQLDialect"/>
<property name="showSql" value="true"/>
<property name="generateDdl" value="false"/>
</bean>
</property>
</bean>

<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
<property name="entityManagerFactory" ref="entityManagerFactory"/>
<property name="dataSource" ref="dataSource"/>
</bean>

<tx:annotation-driven transaction-manager="transactionManager" />

<bean class="org.springframework.orm.jpa.support.PersistenceAnnotationBeanPostProcessor" />

<bean class="org.springframework.dao.annotation.PersistenceExceptionTranslationPostProcessor"/>

上面的某些属性可能会根据您的需要进行更改或添加。该示例适用于您可能已经猜到的带有 Hibernate 和 PostgreSQL 数据库的 JPA。

现在您可以像这样简单地定义您的数据访问方法:

@Repository
@Transactional
public class UserJpaDAO {

protected EntityManager entityManager;

@PersistenceContext
public void setEntityManager(EntityManager entityManager) {
this.entityManager = entityManager;
}

public void save(User theUser) {
entityManager.persist(theUser);
}

public User update(User theUser) {
return entityManager.merge(theUser);
}
}

其中 User 是您的应用程序定义的 JPA 实体。您可以在调用您的 DAO 的管理器/ Controller 层管理事务 - 事实上我就是这样做的 - 但我将它们放在一起,以免使示例过于困惑。

您可能想直接引用而不是我的示例的很好的引用是 http://icoloma.blogspot.com/2006/11/jpa-and-spring-fucking-cooltm_26.html它引用的前 3 个链接也值得一试。

关于hibernate - Spring 的自动 hibernate 事务管理?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/758050/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com