JPA:如何在独立的Java应用程序中持久化后获取Id

时间:2012-04-05 21:03:28

标签: java jpa persistence eclipselink

这是一个独立的Java应用程序,而不是Web应用程序。所以,当我坚持像这样的对象时

public <T> T create(T t) {
    em.getTransaction().begin();
    em.persist(t);
    em.flush();
    em.getTransaction().commit();
    return t;
}

即使在数据库中正确创建了具有正确数据和id的新行,id对象内的T t仍为空。通常在我使用@EJB的网络应用中,id在我坚持之后就可用了,因为它将实体对象持久存储到我的持久化上下文中,我不确定我是否有持久化上下文?

这是我在@Entity Class

中映射我的id的方式
@Id
@Basic(optional = false)
@Column(name = "ID")
private Long id;

我也在数据库AUTO_INCREMENT中创建此表的id,就像这个

一样
CREATE TABLE Config
(
    ID int NOT NULL AUTO_INCREMENT,
    PRIMARY KEY (ID)
)

这就是我获取EntityManager的方式

EntityManagerFactory emf = Persistence.createEntityManagerFactory("CorePU");
em = emf.createEntityManager();

以下是persistence.xml

中的内容
<persistence-unit name="CorePU" transaction-type="RESOURCE_LOCAL">
<provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>    
<class>com.wf.docsys.core.model.Config</class>    
<properties>
  <property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/XNINFODB"/>
  <property name="javax.persistence.jdbc.password" value="xxx"/>
  <property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver"/>
  <property name="javax.persistence.jdbc.user" value="xxx"/>
</properties>

请帮助,我不确定我在这里做错了什么。

4 个答案:

答案 0 :(得分:4)

尝试在您的ID字段中添加@GeneratedValue

答案 1 :(得分:1)

正如我在this post上发现的那样,EntityManager有一个名为refresh的方法,在你坚持下去后会更新你的对象。

所以你的代码可能会是这样的:

public <T> T create(T t) {
    em.getTransaction().begin();
    em.persist(t);
    em.refresh(t);
    em.flush();
    em.getTransaction().commit();
    return t;
}

我还没有对此进行过测试,所以我不确定刷新方法调用的确切位置,在提交之后,刷新之后等等。

希望它可以帮到你。

祝你好运。

答案 2 :(得分:1)

我知道这不是持久性的,但合并将更简单地做同样的事情。我将我的persist包装在一个实际的合并操作中,如果它不存在,它将保存实体。

public T persist(T obj) {
    EntityManager em = ThreadLocalPersistenceManager.getEntityManager();

    EntityTransaction tx = em.getTransaction();
    try {
        tx.begin();
        obj = em.merge(obj);
    } finally {
        if (! tx.getRollbackOnly()) {
            tx.commit();
        }
    }

    return obj;
}


/**
 * This will save the object and return the id of the persisted object.
 *  
 * @param obj
 * @return The id of the persisted object.
 */
public Long save(T obj) {
    persist(obj);
    return obj.getId();
}

答案 3 :(得分:0)

这是我的答案。测试

在映射您的ID时,请切换上面的内容,即

@Id
@Basic(optional = false)
@Column(name = "ID")
private Long id;

@Entity
public class Person {
   @Id
   @TableGenerator(name="TABLE_GEN", table="SEQUENCE_TABLE", pkColumnName="SEQ_NAME",
       valueColumnName="SEQ_COUNT", pkColumnValue="PERSON_SEQ")
   @GeneratedValue(strategy=GenerationType.TABLE, generator="TABLE_GEN")
   private long id;
   ...
}

由于我使用的是Microsoft SQL Server,因此我必须使用@TableGenerator。更多信息可以在http://en.wikibooks.org/wiki/Java_Persistence/Identity_and_Sequencing#Table_sequencing

找到