2

多対多のリレーションシップをピボット テーブルに保存する際に問題があります。

残念ながら、pojo が作成される方法はかなり長いプロセスであり、最終的に永続化されるまで、(この時点ではまだ保存されていない) オブジェクトで動作するいくつかの異なるスレッドにまたがります。関連オブジェクトを作成した直後に相互に関連付けます。デバッグ時に、それぞれのオブジェクトが取り込まれた関連オブジェクトのリストを確認できます。したがって、基本的にはここまでで問題ありません。オブジェクトを永続化すると、ピボット テーブルの関係を除いてすべてが保存されます。

マッピング ファイル:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="com.thebeansgroup.jwinston.plugin.orm.hibernate.object">
    <class name="ShowObject" table="show_object">
        <id name="id">
            <generator class="native" />
        </id>
        <property name="name" />
        <set cascade="all" inverse="true" name="venues" table="venue_show">
            <key column="show_id"/>
            <many-to-many class="VenueObject"/>
        </set>
    </class>
</hibernate-mapping>

そして他の

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="com.thebeansgroup.jwinston.plugin.orm.hibernate.object">
    <class name="VenueObject" table="venue_object">
        <id name="id">
            <generator class="native"/>
        </id>
        <property name="name"/>
        <property name="latitude" type="integer"/>
        <property name="longitude" type="integer"/>
        <set cascade="all" inverse="true" name="shows" table="venue_show">
            <key column="venue_id"/>
            <many-to-many class="ShowObject"/>
        </set>
    </class>
</hibernate-mapping>

ポジョ:

public class ShowObject extends OrmObject
{

    private Long id;
    private String name;
    private Set venues;

    public ShowObject()
    {
    }

    public Long getId()
    {
        return id;
    }

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

    public String getName()
    {
        return name;
    }

    public void setName(String name)
    {
        this.name = name;
    }

    public Set getVenues()
    {
        return venues;
    }

    public void setVenues(Set venues)
    {
        this.venues = venues;
    }
}

そして他の:

public class VenueObject extends OrmObject
{

    private Long id;
    private String name;
    private int latitude;
    private int longitude;
    private Set shows = new HashSet();

    public VenueObject()
    {
    }

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    public Long getId()
    {
        return id;
    }

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

    public int getLatitude()
    {
        return latitude;
    }

    public void setLatitude(int latitude)
    {
        this.latitude = latitude;
    }

    public int getLongitude()
    {
        return longitude;
    }

    public void setLongitude(int longitude)
    {
        this.longitude = longitude;
    }

    public String getName()
    {
        return name;
    }

    public void setName(String name)
    {
        this.name = name;
    }

    public Set getShows()
    {
        return shows;
    }

    public void setShows(Set shows)
    {
        this.shows = shows;
    }
}

問題は注釈の欠如に関連している可能性がありますか?

4

1 に答える 1

2

試してみるいくつかのこと:

  1. inverse="true"多対多の両端にあります。片端だけにする必要があります。

  2. セットを怠惰にしないでください。

  3. column多対多タグのプロパティが指定されていません。

したがって、最終的には次のようになります。

<class name="ShowObject" table="show_object">
    ...
    <set lazy="false" cascade="all" name="venues" table="venue_show">
        <key column="show_id"/>
        <many-to-many class="VenueObject" column="venue_id" />
    </set>
</class>

<class name="VenueObject" table="venue_object">
    ...
    <set lazy="false" cascade="all" inverse="true" name="shows" table="venue_show">
        <key column="venue_id"/>
        <many-to-many class="ShowObject" column="show_id"/>
    </set>
</class>
于 2010-05-20T15:09:16.317 に答える