5

これは Web アプリケーションではなく、スタンドアロンの Java アプリケーションです。したがって、このようにオブジェクトを永続化すると

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

正しいデータと ID を持つ新しい行がデータベース内に正しく作成されても、オブジェクトのid内部はまだ null です。通常、永続化コンテキストにエンティティ オブジェクトを永続化するため、永続化直後に使用できるT tを使用する Web アプリでは@EJB、ここに永続化コンテキストがあるかどうかわかりません。id

これは、@Entityクラス内で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

4 に答える 4

4

@GeneratedValueid フィールドにを追加してみてください。

于 2012-04-05T21:21:21.800 に答える
1

私はそれが永続的ではないことを知っていますが、マージは同じことをより簡単に行います。存在しない場合にエンティティを保存する実際のマージ操作で永続化をラップします。

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();
}
于 2013-02-22T22:53:00.720 に答える
1

この投稿で見つけたように、EntityManager にはrefreshというメソッドがあり、オブジェクトを永続化した後にオブジェクトを更新します。

したがって、コードはおそらく次のようになります。

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

私はこれをテストしていないので、コミット後、フラッシュ後など、refresh メソッド呼び出しを正確にどこに置くべきかわかりません。

それがあなたを助けることを願っています。

幸運を。

于 2012-04-06T00:04:22.690 に答える
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サーバーを使用しているので、使用する必要があります@TableGenerator。詳細については、http://en.wikibooks.org/wiki/Java_Persistence/Identity_and_Sequencing#Table_sequencingを参照してください。

于 2012-04-05T23:49:43.477 に答える