给hibernate的Set增加死条件筛选

参照Hibernate官方文档:http://docs.jboss.org/hibernate/orm/3.3/reference/en/html/collections.html


之前用Hibernate写的系统,其中有一个大家都在公用的附件表Appendix。A模块需要的附件存在这里,B模块需要的附件也存在这里,除了存A或B或C或D...模块的ID以外,还存一个table_name字段,用来区分是A、B、C、D中的哪一个。比如id=5, table_name='B',那么就代表id为5的B模块中的附件。

作为Hibernate的Newbie,只知道用一列映射,于是当初就是这么写的:

        <set name="appendixs">
            <key>
                <column name="id"/>
            </key>
            <one-to-many class="beans.Appendix"/>
        </set>

然后再在程序里用java手动去过滤它们……= =

但是后来发现保存的时候斯巴达。保存的时候会把其他连带的也覆盖掉了。比如id为5的B的附件全删除了,我就b.setAppendixs(null); 这一写不要紧,id为5的A、C、D中的附件也全都消失了……最要命的是这项目已经在客户那边上线了,还要做大手术是风险很高的……Leader告诉我慢慢改,改了出了问题再说(囧。

我实在是不甘心,觉得应该有其他的更优雅的解决方案的才对……查来查去,在Hibernate文档里终于找到了这货,where...

        <set name="appendixs" where="table_name='B'">
            <key>
                <column name="id"/>
            </key>
            <one-to-many class="beans.Appendix"/>
        </set>

这样写死就OK了。ABCD的hbm配置文件都改一下,只需要改配置就可以了。问题解决了。

如果不是写死,而是用动态的话……貌似得用filter标签什么的,就不太了解了。Hibernate的路,我还有很长要走啊……

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值