今天发现一个hibernate的bug,或者说一个应该注意的地方比较合适
来源:互联网 发布:数据分析师 薪水 编辑:程序博客网 时间:2024/05/16 23:58
今天把myblog用sql server部署了一下,可是发现分页查询的时候出现错误,看控制台报错说语句有错,由来发现分页的时候先查询总记录数目的那条语句出错了
原来开发的时候我是用的mysql,没有任何问题。原因就在最后面的order by 语句,sql server 在select count(*)里面不能用 order by。然后跟踪代码发现:
原来问题就在Criteria.addOrder(Order.desc("postTime"));这句话的位置上面,int totalCount = ((Integer) criteria.setProjection(Projections.rowCount())
.uniqueResult()).intValue();
这句话的时候就会生成上面那句话,如果在这之前addOrder就会出现问题,如果你用mysql不会出现问题,如果你用sql server就会报错。解决方法就是把addOrder语句放到totalCount下面就可以了。
这样生成的sql语句就是这样的。
以后大家也要注意了。呵呵。
select count(*) as y0_ from myblog_Blog this_ inner join myblog_Blog_Category categories3_ on this_.id=categories3_.blogId inner join myblog_Category category1_ on categories3_.categoryId=category1_.id where category1_.id=? order by this_.postTime desc
原来开发的时候我是用的mysql,没有任何问题。原因就在最后面的order by 语句,sql server 在select count(*)里面不能用 order by。然后跟踪代码发现:
public PaginationSupport getBlogsByCategoryByPage(final String categoryId, final int startIndex, final int pageSize) { return (PaginationSupport) getHibernateTemplate().execute(new HibernateCallback() { public Object doInHibernate(Session session) throws HibernateException { Criteria criteria = session.createCriteria(Blog.class); Criteria cateCriteria = criteria.createCriteria("categories"); cateCriteria.add(Expression.eq("id",categoryId)); criteria.addOrder(Order.desc("postTime")); int totalCount = ((Integer) criteria.setProjection(Projections.rowCount()) .uniqueResult()).intValue(); criteria.setProjection(null); List items = criteria.setFirstResult(startIndex).setMaxResults(pageSize).list(); List blogs = new ArrayList(); for(Iterator ite = items.iterator(); ite.hasNext();) { Object[] objs = (Object[])ite.next(); blogs.add(objs[1]); } PaginationSupport ps = new PaginationSupport(blogs, totalCount, pageSize, startIndex); return ps; } }, true); }
原来问题就在Criteria.addOrder(Order.desc("postTime"));这句话的位置上面,int totalCount = ((Integer) criteria.setProjection(Projections.rowCount())
.uniqueResult()).intValue();
这句话的时候就会生成上面那句话,如果在这之前addOrder就会出现问题,如果你用mysql不会出现问题,如果你用sql server就会报错。解决方法就是把addOrder语句放到totalCount下面就可以了。
public PaginationSupport getBlogsByCategoryByPage(final String categoryId, final int startIndex, final int pageSize) { return (PaginationSupport) getHibernateTemplate().execute(new HibernateCallback() { public Object doInHibernate(Session session) throws HibernateException { Criteria criteria = session.createCriteria(Blog.class); Criteria cateCriteria = criteria.createCriteria("categories"); cateCriteria.add(Expression.eq("id",categoryId)); int totalCount = ((Integer) criteria.setProjection(Projections.rowCount()) .uniqueResult()).intValue(); criteria.setProjection(null); /* * Fix a bug ,Order must add after get the totalCount, * beacuse SqlServer not support order by in the select count(*). */ criteria.addOrder(Order.desc("postTime")); List items = criteria.setFirstResult(startIndex).setMaxResults(pageSize).list(); List blogs = new ArrayList(); for(Iterator ite = items.iterator(); ite.hasNext();) { Object[] objs = (Object[])ite.next(); blogs.add(objs[1]); } PaginationSupport ps = new PaginationSupport(blogs, totalCount, pageSize, startIndex); return ps; } }, true); }
这样生成的sql语句就是这样的。
select count(*) as y0_ from myblog_Blog this_ inner join myblog_Blog_Category categories3_ on this_.id=categories3_.blogId inner join myblog_Category category1_ on categories3_.categoryId=category1_.id where category1_.id=?
以后大家也要注意了。呵呵。
- 今天发现一个hibernate的bug,或者说一个应该注意的地方比较合适
- 今天发现一个hibernate的bug,或者说一个应该注意的地方比较合适
- 今天发现了一个有趣的地方
- 作为一个程序员应该注意的地方
- 今天发现一个 vc 的大 bug
- 今天发现UltraEdit32的一个bug
- 今天发现校友录的一个Bug
- 今天发现Photoshop的一个bug
- 今天发现一个BUG
- 今天发现一个上传图片的好地方
- android程序登录或者欢迎activity应该注意的地方---超级bug
- 今天第一次改Makefile 有一个值得注意的地方
- 今天发现了vmware6.o ace的一个bug
- 今天无意中又发现一个记事本的 bug
- 今天发现的kali rolling中的一个翻译bug
- 如何发现一个合适的程序员
- 发现CSDN的一个Bug
- 发现一个jet2的bug
- SQL Server TB 级别数据库文件快速初始化
- Iframe仿Ajax异步上传文件(图片)
- 第一章
- hdu2036 求多边形面积
- SQL Server Backup/Restore具体做什么
- 今天发现一个hibernate的bug,或者说一个应该注意的地方比较合适
- DoDataExchange函数
- DB Server CPU 使用率100%
- 18条人情规则
- 谈谈:.Net中的序列化和反序列化
- Linux虚拟内存实现原理
- stl格式说明和stl文件生成(ascII,binary),vs2005,文件生成后imageware读取成功
- [译]人脸检测与人脸识别简介
- pango_font_description_from_string设置字体