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