0

我无法使用 spring 和 hibernate 持久化数据。我查看了各种帖子并尝试了很多东西。但它只是行不通。我将首先发布我的配置,然后发布我尝试的步骤。将不胜感激任何帮助。

spring-jpa.xml

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

<bean id="defaultLobHandler" class="org.springframework.jdbc.support.lob.DefaultLobHandler" />

<context:component-scan base-package="com.gamelist.dao.classes" />

<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager" p:entityManagerFactory-ref="entityManagerFactory"/>

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

通用DAO.java

public class GenericDaoJPA<T extends IDomainObject> implements IGenericDao<T> {

protected EntityManager entityManager;

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

    public void save(T object) throws DataAccessException{
    entityManager.persist(object);
}
.
.
. 
.
}

User.java(域)

@Entity
@Table(name = "user")
public class User implements Serializable, IDomainObject{
private long id;
private String firstName;

@Id
@GeneratedValue
public final long getId(){
    return id;
}

public void setId(long id){
    this.id = id;
}

public String getFirstName(){
    return firstName;
}

public void setFirstName(String firstName){
    this.firstName = firstName;
}
}

TestService.java(UserDao 实现 IUserDao 并扩展 GenericDao)

@Service(value = "testService")
@Transactional
public class TestService implements ITestService {
 @Autowired
private IUserDao userDao;

@Transactional(readOnly = false)
public void saveUser(User newUser){
    userDao.save(newUser);
}
.
.
.
}

持久性.xml

<persistence-unit name="gamelistPersistenceUnit" transaction-type="RESOURCE_LOCAL">
    <provider>org.hibernate.ejb.HibernatePersistence</provider>
    <properties>
        <property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5Dialect"/>
        <!--
            value='create' to build a new database on each run;
            value='update' to modify an existing database;
            value='create-drop' means the same as 'create' but also drops tables when Hibernate closes;
            value='validate' makes no changes to the database
         -->
    </properties>

</persistence-unit>

我没有收到任何错误或异常或任何东西。我可以从我的数据库中读取。仅更新、添加或删除不持久。

这是我尝试过的所有内容

  1. 一篇文章提到将 transaction-type="RESOURCE_LOCAL" 更改为 JTA 说 RESOURCE_LOCAL 根本不存在。我认为这是如果您在使用 RESOURCE_LOCAL 时仅使用休眠而不管理事务。我相信 spring 会为您管理交易。
  2. 有人提到在使用持久化后执行 em.flush 或 em.getTransaction.begin 并提交。但是每次使用上述操作时都会出现此错误。不允许在共享 EntityManager 上创建事务

任何帮助表示赞赏。提前致谢

4

1 回答 1

0

提交 TX(或刷新 Hibernate)失败。您的声明性事务性不起作用,或者声明需要进一步扩展。

不应该将 DAO 声明为事务性的吗?那是实际发生动作的地方,您在 TestService 处的“事务”声明本身实际上并没有做任何事情——因此 Spring 可能会错过将 HB 加入事务。

我自己通常不使用声明性,因为我发现 TX 边界很容易且在用户活动中定义明确——并且在显式编码时更可跟踪/更可靠(1 行,通过我的帮助程序类)。

坦率地说,我也不知道你希望用你的 DAO 做什么——如果你使用 JPA/Hibernate,这些层会处理 DAO 会做什么。我怀疑你正在用无所事事的类来充实你的应用程序,你不了解它们的正确目的/用途。

有什么问题:

Session hb = HbHelper.session();
hb.save( user);
HbHelper.commit();  // commits via a TX.

我将此样式与“OpenSessionInView”过滤器一起使用。

于 2013-08-03T05:58:49.700 回答