免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1043 | 回复: 0
打印 上一主题 下一主题

hibernate Set排序 [复制链接]

论坛徽章:
26
处女座
日期:2016-04-18 14:00:4515-16赛季CBA联赛之深圳
日期:2020-06-02 10:10:5015-16赛季CBA联赛之广夏
日期:2019-07-23 16:59:452016科比退役纪念章
日期:2019-06-26 16:59:1315-16赛季CBA联赛之天津
日期:2019-05-28 14:25:1915-16赛季CBA联赛之青岛
日期:2019-05-16 10:14:082016科比退役纪念章
日期:2019-01-11 14:44:062016科比退役纪念章
日期:2018-07-18 16:17:4015-16赛季CBA联赛之上海
日期:2017-08-22 18:18:5515-16赛季CBA联赛之江苏
日期:2017-08-04 17:00:4715-16赛季CBA联赛之佛山
日期:2017-02-20 18:21:1315-16赛季CBA联赛之天津
日期:2016-12-12 10:44:23
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-11-11 11:13 |只看该作者 |倒序浏览

大家都知道one-to-many的排序可以通过配置一个order-by="** desc"即可实现
如:
代码
set name="clubMessage" table="club_Message" inverse="true" cascade="delete" order-by="create_time desc">
    key column="club_id" />
    one-to-many class="com.test.item.club.domain.ClubMessageVO" />
/set>
上面的hbm属性意义是:一个社区对应多条社区消息,同时将这些消息按create_time排序
  
import java.util.Comparator;
   
import my.User;
   
public class GBComparator implements Comparator{
   
    public int compare(Object o1, Object o2){
        if(o1 == null){
            return o2 == null ? 0 : 1;
        }
        if(o2 == null){
            return -1;
        }
            
        if(o1 instanceof User && o2 instanceof User){
            return ((User)o1).getAccount().compareTo(((User)o2).getAccount());
        }
            
        return 0;
    }
}
set
            name="users"
            table="USER_GROUP_REL"
            cascade="none"
            inverse="true"
            sort="my.GBComparator">
            key column="GROUPING_ID" />
            many-to-many column="USER_ID" class="User" />
        /set>



本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u/29375/showart_1404890.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP