hibernate的继承分页bug:firstResult/maxResults specified on polymorphic query; applying in memory!

hibernate的继承分页bug:firstResult/maxResults specified on polymorphic query; applying in memory!

今天遇到了一个大问题,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>

</class>


然后你再用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


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值