HibernateTemplate的findByCriteria关于排序问题求解

okxiehui 2012-08-13 08:25:03
在使用HibernateTemplate使用翻页功能遇到一个问题,小弟不才百思不得其解,未能彻底了解HibernateTemplate故向大侠们求解,望不吝赐教

代码如下:
DetachedCriteria d= DetachedCriteria.forClass( Test.class);
d.addOrder(Order.desc("time"));
getHibernateTemplate().findByCriteria(filter, pageNumber * pageSize, pageSize);

执行第一页生成对应的SQL如下:
select * from ( select this_.STCD as STCD1_0_, this_.TM as TM1_0_, this_.Z as Z1_0_, this_.Q as Q1_0_ from ST_R this_ order by this_.TM desc ) where rownum <= ?
执行第二页和之后页数都会对应的SQL如下:
select * from ( select row_.*, rownum rownum_ from ( select this_.STCD as STCD1_0_, this_.TM as TM1_0_, this_.Z as Z1_0_, this_.Q as Q1_0_ from ST_R this_ order by this_.TM desc ) row_ ) where rownum_ <= ? and rownum_ > ?
使用的是oracle数据库。
第一句SQL和第二句SQL的ROWNUM,由于取的方式不一样可能会造成同一条数据在第一页和第二页中出现而有的数据则不会取出来。。
...全文
285 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
okxiehui 2012-08-14
  • 打赏
  • 举报
回复
呵呵,这是昨天发重了的,不是这个。

[Quote=引用楼主 的回复:]
在使用HibernateTemplate使用翻页功能遇到一个问题,小弟不才百思不得其解,未能彻底了解HibernateTemplate故向大侠们求解,望不吝赐教

代码如下:
DetachedCriteria d= DetachedCriteria.forClass( Test.class);
d.addOrder(Order.desc("time"));
getHibernateTem……
[/Quote]
MiceRice 2012-08-14
  • 打赏
  • 举报
回复
“谢谢您的回复,我之前对hibernat自动生成的SQL有疑问,但现在很诡异的事情,另发一帖上图,希望您能解答”

咋是同一个问题。。。

67,513

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧