Hibernate多对多映射未保存在数据透视表中

时间:2010-05-20 13:40:50

标签: java hibernate multithreading annotations pojo

我在向数据透视表保存多对多关系时遇到问题。

不幸的是,创建pojos的方式是一个非常漫长的过程,它跨越了几个不同的线程,这些线程处理(到此时未保存)对象,直到它最终被持久化。我在创建相关对象后立即将它们相互关联,并且在调试时我可以看到用相应对象填充的相关对象列表。所以基本上一切都很好。当我持久保存对象时,除了数据透视表中的关系外,所有内容都会被保存。

映射文件:

<?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>

的POJO:

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;
    }
}

问题可能与缺少注释有关吗?

1 个答案:

答案 0 :(得分:2)

尝试一些事情:

  1. 您在多对多的两端都有inverse="true"。它应该只在一端。

  2. 让你的套装不要懒惰。

  3. 您没有为多对多标记指定column属性。

  4. 所以最后看起来应该是这样的:

    <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>