hibernate 配置Set排序

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

 

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

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

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

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

 

(二)使用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;
      }

}


//如果支持泛型,可写成:

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

      ...

      public int compare(AsStandard o1, AsStandard o2 ) {                 // 2.实现方法compare
                if(o1.stId>o2.stId){
                         return -1;
                }
                return 1;
      }

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值