1

私はこのような2つのマッピングを持っています:

<hibernate-mapping>  
    <class name="A" table="A">  
        <id name="code" column="aCode" type="integer">  
            <generator class="assigned"/>  
        </id>  
        <property name="info" type="integer"/>  
        <set name="Bs" lazy="false">
            <key>
                <column name="aCode" not-null="true"/>
            </key>
            <one-to-many class="B"/>
        </set>
    </class>  
    <class name="B" table="B">  
        <id name="code" column="bCode" type="integer">  
             <generator class="assigned"/>  
        </id>  
        <many-to-one name="a"/>  
    </class>  
</hibernate-mapping>  

これらはクラスです:

public class A {  
    private int code;  
    private int info;  
    private Set<B> bs = new HashSet<B>(0);  
    public A() {};  
    public int getCode() { return code; }  
    public void setCode(int code) { this.code = code; }  
    public int getInfo() { return info; }  
    public void setInfo(int info) { this.info = info; }  
    public Set<B> getBs() { return bs; }  
    public void setBs(Set<B> bs) { this.bs = bs; }  
}

public class B {  
    private int code;  
    private A a;  
    public B() {};  
    public int getCode() { return code; }  
    public void setCode(int code) { this.code = code; }  
    public A getA() { return a; }  
    public void setA(A a) { this.a = a; }  
}  

私は長い移行に対処し、次のことをしなければならないシナリオにいます:

// Persistence Layer
Session session = factory.getCurrentSession();  
session.beginTransaction();  

A a1 = new A(); // Create transient object  
a1.setCode(1);  
a1.setInfo(10);  
session.save(a1); // Persist it  

// Something happening in another layer (see below)

// Continuing with the transaction
Object b = ... // Recover object
session.save(b); // Persist it using transient a2 object as a link but don't change/update its data

System.out.println(b.getA().getInfo()); // Returns 0 not 10;  
session.commit();  

これは別のレイヤーで発生します(ここではセッションにアクセスできません):

// * Begin in another layer of the application *  
A a2 = new A(); // Create another transient object same *code* as before  
a2.setCode(1);  
B b = new B(); // Create another transient object  
b.setCode(1);  
b.set(a2);  
// * End and send the b Object to the persistence layer *  

親オブジェクトを保存する前に永続的な子オブジェクトをロード/取得する方法はありますか、または情報を変更せずに子オブジェクトを保存してすべてをフラッシュする他の方法はありますか?JPAを使用していません。ひどく間違っていたらごめんなさい。

ありがとうございました。

4

2 に答える 2

2

現在、関係にカスケードがないため、新しい子の状態はデータベースに保存されません。したがって、子の状態が間違っていても大きな問題にはなりません。

ただし、メモリ内のエンティティの状態を一貫させたい場合は、カスケードせずに、merge()の代わりに使用できますsave()。これは、希望どおりに機能するはずです。

b = session.merge(b); // Persist it using transient a2 object as a link but don't change/update its data  
System.out.println(b.getA().getInfo()); // Should return 10

参照:

于 2011-02-07T11:17:52.700 に答える
0

私はあなたがしたいことは次のとおりだと思います:

A a2 = (A)session.get(A.class, 1);
于 2011-02-07T07:31:09.750 に答える