hibernate 配置Set排序

hibernate 中对set对象的两种配置方法:

(一)使用order-by对set排序,只需要修改set设置:

<set name="standards" ... order-by="st_id desc" >
...
</set>

//注意:st_id必须是数据表里的字段名,不能使类里的属性名

//使用order-by,实质是hibernate自动在查询语句后面添加order by ...语句。

//private Set<AsStandard> standards = new HashSet<AsStandard>();

 

(二)使用sort对set排序

1.修改set设置:

<set name="standards" ... sort="mypack.module.AsStandard" >
...
</set>

注意:

           属性standards要定义成:

           private Set<AsStandard> standards = new TreeSet <AsStandard>();

            不能定义成HashSet ,否则不能用sort进行排序。

 

2.修改实体类AsStandard:

public class AsStandard implements Comparator {           // 1.实现接口Comparator

      ...

      public int compare (Object o1, Object o2) {                  // 2.实现方法compare
              if(o1 instanceof AsStandard && o2 instanceof AsStandard){
                         AsStandard r1 = (AsStandard)o1;
                          AsStandard r2 = (AsStandard)o2;
                         if(r1.stId>r2.stId){          //stId是类里的属性名,不是数据表里的字段名
                                     return 1;
                         }
              }
             return -1;
      }

}

posted @ 2012-11-19 18:28  雨心竹  阅读(2676)  评论(0编辑  收藏  举报