如何使用Hibernate Annotation在其中使用自身列表注释实体

时间:2012-05-13 12:56:31

标签: hibernate hibernate-annotations

我有一个类别实体,其类别为父级,类别列表为子级。这是它的声明:

@Entity
@Table(name="CATEGORYENTITY")
public class CategoryEntity extends BaseEntity<Long> {
    private static final long serialVersionUID = 1L;

    @Id
    @GeneratedValue
    @Column(name="ID")
    private Long id;

    @Column(name="NAME")
    private String name;

    @Column(name="VIEWSCOUNT")
    private Integer viewsCount;

    @OneToMany(fetch=FetchType.EAGER, cascade={CascadeType.PERSIST, CascadeType.MERGE, CascadeType.REFRESH})
    @Cascade(org.hibernate.annotations.CascadeType.SAVE_UPDATE)
    @JoinColumn(name="CATEGORY_ID")
    private List<CategoryEntity> childCategories;

    @ManyToOne(fetch=FetchType.EAGER)
    @JoinColumn(name="CATEGORY_ID")
    private CategoryEntity parent;

setters and getters...

保存和更新时工作正常但是当试图获得所有类别时...每个孩子都会返回父母!我的意思是如果我有一个mainCat并且这个mainCat有4个孩子,例如,当从db获取所有类别时,它返回所有四个孩子,令人惊讶的是4个mainCat ...奇怪的部分是返回的对象是正确的,它们的属性是设置正确,4 mainCat是一样的!我该怎么办?

我使用以下代码来检索结果:

public List<E> find(E example, final PagingObject paging, Map<?, ?> filter) throws Exception {
    // create the criteria
    final DetachedCriteria detachedCriteria = createCriteria(filter);
    // add restrictions to the criteria based on example entity
    pruneCriteria(detachedCriteria, example);
    List<E> result = getHibernateTemplate().execute(new HibernateCallback<List<E>>() {
        @SuppressWarnings("unchecked")
        @Override
        public List<E> doInHibernate(Session session) throws HibernateException, SQLException {
            // attach criteria to the session
            Criteria criteria = detachedCriteria.getExecutableCriteria(session);
            // add paging and sort to the criteria
            paginate(criteria, paging);
            List<E> list = criteria.list();
            return list;
        }
    });
    return result;
}

1 个答案:

答案 0 :(得分:2)

双向关联始终具有所有者方和反方。所有者方是您定义关联映射方式的方(使用@JoinColumn)。相反,您不能定义关联的映射方式(这将是多余的)。但是你必须通过使用mappedBy属性来定义它是反面的。

您没有定义父子双向关联,而是定义了两种不同的关联。

集合的映射应该是:

@OneToMany(mappedBy = "parent",
           fetch=FetchType.EAGER, 
           cascade={CascadeType.PERSIST, CascadeType.MERGE, CascadeType.REFRESH})
@Cascade(org.hibernate.annotations.CascadeType.SAVE_UPDATE)
private List<CategoryEntity> childCategories;

请注意,将此类关联的两侧设置为EAGER将强制Hibernate在每次加载树的单个节点时加载整个树。准备好处理大量的查询以及糟糕的性能。