`
somebody
  • 浏览: 81298 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

今天发现一个hibernate的bug,或者说一个应该注意的地方比较合适

阅读更多
今天把myblog用sql server部署了一下,可是发现分页查询的时候出现错误,看控制台报错说语句有错,由来发现分页的时候先查询总记录数目的那条语句出错了
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教程26_事务并发处理

    s2sh_relation26_optimistic_Lock.zip可能包含了一个示例,演示了如何在实体类中定义版本字段,并在Service或DAO中处理乐观锁的逻辑。 学习这两个锁机制对于开发人员来说非常重要,因为它们有助于决定在特定场景下...

    hibernate-release-5.2.16.Final + slf4j

    Hibernate是一个开放源代码的对象关系映射(ORM)框架,它允许开发者使用面向对象的方式来处理数据库操作。在5.2.16.Final版本中,Hibernate提供了一套完整的解决方案,包括实体管理、查询语言、缓存策略以及事务...

    hibernate-bug-1:演示在将@MapKey与映射到@SecondaryTable的目标属性一起使用时在Hibernate中的错误

    本篇文章将深入探讨一个特定的问题:“hibernate-bug-1”,即在使用@MapKey与映射到@SecondaryTable的目标属性时出现的错误。 首先,我们需要理解@MapKey和@SecondaryTable这两个注解的用途。@MapKey是Hibernate...

    slf4j-1.6.0.zip

    SLF4J(Simple Logging Facade for Java)是Java日志框架的一个接口层,它为各种日志实现提供了一个统一的API,比如Log4j、java.util.logging、Logback等。在开发过程中,使用SLF4J可以让我们的代码与具体日志实现...

    计算机实习日记 (2).docx

    这通常意味着服务器遇到了一个未预期的异常,可能是由于配置错误、代码bug或者是数据库连接问题导致的。解决这类问题通常需要查看服务器日志以获取更具体的错误信息。在这个例子中,日志显示“数据加载失败”,暗示...

    用Java开发的对农业生产管理的一个养猪系统.zip

    总的来说,这个基于Java的养猪管理系统通过集成现代信息技术,为养猪场提供了全面、细致的管理手段,提升了农业生产管理的效率和精准度,是现代农业智能化转型的一个典型示例。在未来,随着技术的不断进步,我们可以...

    NBearV3.7.2_binary.zip

    `release-notes.txt` 文件是关于版本更新的重要文档,其中详细列出了NBearV3.7.2相对于前一个版本的改进、新增功能、已知问题和修复的bug。开发者在升级或初次使用这个版本时,应仔细阅读这份文档以了解可能影响他们...

    学生活动信息管理系统.zip

    《学生活动信息管理系统》是一个综合...总的来说,《学生活动信息管理系统》是一个集成了人工智能、系统分析与设计、Java编程、信息化管理等多个IT领域的综合性项目,旨在通过科技手段提升学生活动管理的效率和质量。

    Java开放源码编程02

    最后,参与到开源社区意味着与全球的开发者共享知识,贡献代码,例如通过提交bug报告、提供建议、编写文档或者直接参与项目开发。这不仅能提升个人技能,也有助于建立专业网络,提高行业影响力。 总的来说,"Java...

    包括应用示例的功能强大的分页组件valuelist0.1.8

    在IT行业中,分页组件是开发网页应用时不可或缺的一部分,特别是在处理大数据量的展示时。本文将详细讨论“包括应用示例的功能强大的分页组件...对于任何处理大量数据的Web应用来说,这是一个非常有价值的工具。

    SsGen(Simple SQL Generator)-开源

    总结来说,SsGen是一个强大的SQL生成工具,它以直观的API和数据库供应商支持为特点,能够简化开发流程,提高代码质量。作为一个开源项目,它鼓励社区参与,促进其持续发展,为开发者提供了更多的选择和便利。

    mysql-connector-java-5.1.47.jar

    MySQL Connector/J 5.1.47 是一个用于Java应用程序与MySQL数据库进行连接的重要组件。它是MySQL官方提供的JDBC(Java Database Connectivity)驱动程序,允许Java开发者通过编写Java代码来执行SQL语句,管理和操作...

Global site tag (gtag.js) - Google Analytics