hibernate继承分页BUG解决

hibernate的继承分页bug。只要加上分页就不查出结果为0……

有个hibernate警告:

[WARN] firstResult/maxResults specified on polymorphic query; applying in memory!

据说具体原因是hibernate本身的一个bug:参见(人家的劳动成果,不好直接粘过来,大家可以去看看)

http://blog.sina.com.cn/s/blog_4a87727d0100d8dm.html

嘿嘿,上午还愁来着呢,现在已经解决了。

主要就是要注意一下继承时配置文件hbm的配置。

比如说person类和Employee类。Employee继承person。

在java文件中就要在Employee类后面加个extends person。

在配置文件中,不在需要单独为Employee类做hbm映射文件。

<class name="Person">

        <!-- 映射标识属性 -->

        <id name="id" column="person_id">

            <!-- 使用identity的主键生成器策略 -->

            <generator class="identity"/>

        </id>

        <!-- 以下映射两个基本属性 -->

        <property name="name" length="80"/>

        <property name="gender"/>

        <!-- 使用union-subclass元素映射Person类的Employee子类 -->

        <union-subclass name="Employee" table="Employee">

            <!-- 映射Employee类的两个普通属性 -->

            <property name="title" not-null="true"/>

            <property name="salary" not-null="true"/>

            <!-- 映射Employee类与Manager类之间的N-1关联 -->

            <many-to-one name="manager" column="manager_id"/>

            <!-- 映射Employee类与Customer类之间的1-N关联 -->

            <set name="customers" inverse="true">

                <key column="employee_id"/>

                <one-to-many class="Customer"/>

            </set>

        </union-subclass>

然后你再用hibernate分页就OK啦。

值得注意的是两个红色的地方:

最好class中给出该类的全路径:如cn.rntd.entity.Employee

还有, 在参考文件中为<union-subclass name="Employee">,但是执行是可能会报'表或视图不存在'

所以还是乖乖加上子类对应的table比较好哦:

<union-subclass name="Employee" table="Employee">

union-subclas详细资料参考:http://book.csdn.net/bookfiles/562/10056218641.shtml

http://hi.baidu.com/jiaju1213/blog/item/ab8cefd885fddc2411df9bf2.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值