【问题标题】:Entity manager does not persist data in the DB实体管理器不会将数据保存在数据库中
【发布时间】:2012-07-06 07:35:33
【问题描述】:

通过实体管理器,我试图将实体持久保存在数据库中,但我没有设法持久保存它。这是我的配置。

我有这个实体:

@Entity
@Table(name = "User")
public class UserModel implements Serializable, ModelItem {
    private static final long serialVersionUID = 1L;

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Integer id;

    @Column(nullable = false)
    private String username;

    @Column(nullable = false)
    private String password;

    @Column(nullable = false)
    private String name;

    private String surname;

    private String notes;

    private String cellphone;

    @Column(nullable = false)
    private String email;

    private Boolean enabled;

    //get and set methods
    .....
}

还有我的导入 bean,它执行持久性:

@Repository
public class ImportServiceImpl implements ImportService {

    @PersistenceContext
    protected EntityManager entityManager;

    @Transactional
    public boolean importExample() {
        User u= new User();
        u.setUsername("username");
        u.setPassword("password");
        u.setName("name");
        u.setEmail("email");
        entityManager.persist(u);
    }
}

实体管理器和db连接的spring配置:

<tx:annotation-driven transaction-manager="transactionManager" />
<bean class="org.springframework.orm.jpa.support.PersistenceAnnotationBeanPostProcessor" />
<tx:annotation-driven />
<bean class="org.springframework.dao.annotation.PersistenceExceptionTranslationPostProcessor"/> 
<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
    <property name="dataSource" ref="dataSource" />
    <property name="jpaVendorAdapter">
        <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
            <property name="showSql" value="true" /> <!-- Prints used SQL to stdout -->
            <property name="generateDdl" value="true" /> <!-- Generates tables. -->
            <property name="databasePlatform" value="org.hibernate.dialect.MySQL5Dialect" />
        </bean>
    </property>
</bean>
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
    <property name="url">
        <value>${db.url}</value>
    </property>
    <property name="username">
        <value>${db.username}</value>
    </property>
    <property name="password">
        <value>${db.password}</value>
    </property>
</bean>
<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
    <property name="entityManagerFactory" ref="entityManagerFactory"/>
    <property name="dataSource" ref="dataSource"/>
</bean>

还有我的 persistence.xml

<?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="application" transaction-type="RESOURCE_LOCAL">
    <provider>org.hibernate.ejb.HibernatePersistence</provider>
        <properties>
            <property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/testdata"/>
            <property name="hibernate.connection.driver_class" value="com.mysql.jdbc.Driver"/>
            <property name="hibernate.connection.password" value="password"/>
            <property name="hibernate.connection.username" value="root"/>
            <property name="hibernate.hbm2ddl.auto" value="create-drop"/>
        </properties>

    </persistence-unit>
</persistence>

所以当我运行我的示例时,我没有收到任何错误,但实体没有持久化。我还尝试在坚持后添加 entityManager.flush() 但在这种情况下我收到此错误:

javax.persistence.TransactionRequiredException: no transaction is in progress
    at org.hibernate.ejb.AbstractEntityManagerImpl.flush(AbstractEntityManagerImpl.java:793)

所以我认为我的 Transactional bean 没有很好地绑定到方法,但我无法理解原因。有人知道为什么吗?

我还注意到在 STS 中,为这个事务生成了 2 个具有相同数据的 bean,它看起来很奇怪(我不知道这是 STS 的错误还是我的配置中的问题,它创建了 2 个 bean):

【问题讨论】:

  • 你试过@Transactional(propagation = Propagation.REQUIRED)吗?
  • 仍然无法工作我得到相同的行为......
  • 我在手动将数据插入数据库后测试了 entityManager.find(...) 并且它可以工作,但是持久化不保存数据...为什么? :(
  • 您好!你是如何设法解决这个问题的?我面临着这里描述的类似问题:stackoverflow.com/questions/17643456/…我感谢任何帮助。谢谢

标签: spring jpa


【解决方案1】:

我遇到了与上述类似的问题。 我发现错误使用@Transactional 表示法的问题,特别是我错误地使用了javax.transaction.Transactional 而不是org.springframework.transaction.annotation.Transactional

可以在javax.transaction.Transactional vs org.springframework.transaction.annotation.Transactional这里找到差异的详细描述

【讨论】:

    【解决方案2】:

    也许尝试在@PersistenceContext 注释中指定持久性单元名称“应用程序”?

    @PersistenceContext(unitname = "应用")

    【讨论】:

    • 不...它不起作用!我还将 添加到我的 entityManagerFactory bean 但没有结果
    【解决方案3】:

    我也遇到了同样的问题,因为 Repoker 说 Persistence 提供程序没问题,但我的事务管理器被搞砸了。我像这样在 application-config.xml 中添加了 transactionManager bean

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

    现在可以正常使用了!!

    【讨论】:

    • 你还在用什么?是 RESOURCE_LOCAL 还是 JTA 事务?
    【解决方案4】:

    您可以在坚持并合并后使用entityManager.flush() 可以解决您的问题

    【讨论】:

      【解决方案5】:

      您的上下文配置中有两次&lt;tx:annotation-driven /&gt;。我不确定这是一个合法的配置。

      【讨论】:

        【解决方案6】:

        我有一个类似的问题,@Transactional 没有使用 EntityManager 在数据库中保留实体。为了解决这个问题,我们可以手动提交事务。

        entityManager.getTransaction().begin();
        entityManager.persist(post);
        entityManager.getTransaction().commit();
        

        【讨论】:

          猜你喜欢
          • 2021-08-02
          • 2020-07-01
          • 2018-01-05
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 2021-07-18
          相关资源
          最近更新 更多