如何从对象中包含的一对多关系中对实体进行排序

时间:2013-07-03 17:58:22

标签: hibernate spring-mvc

如何对外键记录进行排序

如何对实体中包含的外键记录进行排序?

我有一对多关系:一个群组可以包含多个网站。

Group.java

public class Group implements java.io.Serializable {

    private static final long serialVersionUID = -3698414318830180024L;

    private Collection<AppSite> appSites = new HashSet<AppSite>();

GroupDAO.java:

public class GroupDAO extends HibernateDaoSupport {

    @SuppressWarnings("unchecked")
    public Group getGroupById(Long id){
        Group group = getHibernateTemplate().get(Group.class, id);
        return group;
}

这是循环这些记录的jsp:

<p>Number of items: ${fn:length(groupCommand.group.appSites)}</p>

<ul>
    <c:forEach items="${groupCommand.group.appSites}" var="appSite">
        <li><a href="../appsites/appsite.page?appSiteId=${appSite.appSiteId}">${appSite.nameEng}</a></li>   
    </c:forEach>
</ul>

问题是appSite.nameEng没有正确排序。如何做到这一点?

到目前为止,我有这个HQL:

from Group as g inner join g.appSites as s where g.appSiteGroupId=10 order by s.nameEng asc

在Eclipse / Hibernate HQL编辑器中,它返回适当数量的记录。但是,当我将DAO方法更改为:

@SuppressWarnings("unchecked")
public Group getGroupById(Long id){
    //Group group = getHibernateTemplate().get(Group.class, id);
    Group group = (Group) getHibernateTemplate().find("from Group as g inner join g.appSites as s where g.appSiteGroupId=10 order by s.nameEng asc").get(0);
    return group;
}

我收到此错误:java.lang.ClassCastException: [Ljava.lang.Object; cannot be cast to org.domain.Group

更新#1

我有这个:

@SuppressWarnings("unchecked")
public Group getGroupById(Long id){
    //Group group = getHibernateTemplate().get(Group.class, id);
    List<Group> groupList= getHibernateTemplate().find("from Group as g inner join g.appSites as s where g.appSiteGroupId=10 order by s.nameEng asc");
    return (groupList.size() > 0 ) ? groupList.get(0) : null; //line 17
}

产生的错误:

java.lang.ClassCastException: [Ljava.lang.Object; cannot be cast to org.domain.Group
    org.dao.GroupDAO.getGroupById(GroupDAO.java:17)

更新#2

另一个尝试,同样的问题

Group.java

public class Group implements java.io.Serializable {

    private Collection<AppSite> appSites = new ArrayList<AppSite>();

AppSiteComparator.java

public class AppSiteComparator implements Comparator<AppSite> {

    private String sortBy;

    public AppSiteComparator(String sortBy){
        this.sortBy = sortBy;
    }

    public AppSiteComparator(){
        this.sortBy = "nameEng";
    }

    @Override
    public int compare(AppSite a1, AppSite a2){
        if(this.sortBy.equals("nameEng"))
            return a1.getNameEng().compareTo(a2.getNameEng());
        else
            return 0;
    }
}

GroupDAO.java

@SuppressWarnings("unchecked")
public Group getGroupById(Long id){
    Group group = getHibernateTemplate().get(Group.class, id);
    Collections.sort((List<AppSite>) group.getAppSites(), new AppSiteComparator());
    return group;
}

错误

java.lang.ClassCastException: org.hibernate.collection.PersistentSet cannot be cast to java.util.List at org.dao.GroupDAO.getGroupById(GroupDAO.java:19)

更新#3

尝试使用标准:

Group group = (Group) session.createCriteria(Group.class)                   
    .createAlias("appSites", "a")
    .add(Restrictions.eq("appSiteGroupId",10L))
    .addOrder(Order.asc("a.nameEng")).list().get(0);

仍然不能正常工作...在控制台中显示的顺序:

Site name: test 4
Site name: Test eng
Site name: test 2
Site name: test 3

刚刚注意到...... SQL似乎是正确的:

Hibernate: select from serverlist.configtool_group this_ inner join serverlist.configtool_app_site a1_ on this_.app_site_group_id=a1_.app_site_group_id where this_.app_site_group_id=? order by a1_.name_eng asc

我错了... appSites属性是在另一个SQL中设置的,它没有任何排序:

Hibernate: select ... from serverlist.configtool_app_site appsites0_ where appsites0_.app_site_group_id=?

1 个答案:

答案 0 :(得分:0)

appSite.nameEng未正确排序

appSite的类型为HashSet。所以天生就没有秩序。

ClassCastException的原因:

在您的查询中:

from Group as g inner join g.appSites as s where g.appSiteGroupId=10 order by s.nameEng asc

您正在加入(内部)两个实体(GroupAppSite),因此查询结果肯定不是Group实体类型。您应该使用list()类的Query方法来处理此类查询。