Hibernate的Set映射(一对多)的排序问题

问题背景:持久化类Privilege存在一对多的关系

public class Privilege implements Serializable{

private Long id;

...

private Set<Privilege> children = new LinkedHashSet<Privilege>();

...

}

在struts2的valueStack栈顶有一个privilege对象,然后我需要在jsp页面里取出其children值: <s:iterator value="children">

但问题是:得到的children集合中的privilege对象是无序的!毕竟是Set集合!


解决方案:在Privilege.hbm.xml中添加配置order-by="id"则将根据id进行顺序查询

<set name="children" cascade="all" inverse="false" lazy="false" order-by="id">
    <key>
    <column name="parent_id"></column>
    </key>
    <one-to-many class="Privilege"/>

</set>

则hibernate在发出sql语句时会添加 “order by...  asc”

如果想要逆序查询,则order-by="id desc"



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值