今天把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=?
以后大家也要注意了。呵呵。
分享到:
相关推荐
s2sh_relation26_optimistic_Lock.zip可能包含了一个示例,演示了如何在实体类中定义版本字段,并在Service或DAO中处理乐观锁的逻辑。 学习这两个锁机制对于开发人员来说非常重要,因为它们有助于决定在特定场景下...
Hibernate是一个开放源代码的对象关系映射(ORM)框架,它允许开发者使用面向对象的方式来处理数据库操作。在5.2.16.Final版本中,Hibernate提供了一套完整的解决方案,包括实体管理、查询语言、缓存策略以及事务...
本篇文章将深入探讨一个特定的问题:“hibernate-bug-1”,即在使用@MapKey与映射到@SecondaryTable的目标属性时出现的错误。 首先,我们需要理解@MapKey和@SecondaryTable这两个注解的用途。@MapKey是Hibernate...
SLF4J(Simple Logging Facade for Java)是Java日志框架的一个接口层,它为各种日志实现提供了一个统一的API,比如Log4j、java.util.logging、Logback等。在开发过程中,使用SLF4J可以让我们的代码与具体日志实现...
这通常意味着服务器遇到了一个未预期的异常,可能是由于配置错误、代码bug或者是数据库连接问题导致的。解决这类问题通常需要查看服务器日志以获取更具体的错误信息。在这个例子中,日志显示“数据加载失败”,暗示...
总的来说,这个基于Java的养猪管理系统通过集成现代信息技术,为养猪场提供了全面、细致的管理手段,提升了农业生产管理的效率和精准度,是现代农业智能化转型的一个典型示例。在未来,随着技术的不断进步,我们可以...
`release-notes.txt` 文件是关于版本更新的重要文档,其中详细列出了NBearV3.7.2相对于前一个版本的改进、新增功能、已知问题和修复的bug。开发者在升级或初次使用这个版本时,应仔细阅读这份文档以了解可能影响他们...
《学生活动信息管理系统》是一个综合...总的来说,《学生活动信息管理系统》是一个集成了人工智能、系统分析与设计、Java编程、信息化管理等多个IT领域的综合性项目,旨在通过科技手段提升学生活动管理的效率和质量。
最后,参与到开源社区意味着与全球的开发者共享知识,贡献代码,例如通过提交bug报告、提供建议、编写文档或者直接参与项目开发。这不仅能提升个人技能,也有助于建立专业网络,提高行业影响力。 总的来说,"Java...
在IT行业中,分页组件是开发网页应用时不可或缺的一部分,特别是在处理大数据量的展示时。本文将详细讨论“包括应用示例的功能强大的分页组件...对于任何处理大量数据的Web应用来说,这是一个非常有价值的工具。
总结来说,SsGen是一个强大的SQL生成工具,它以直观的API和数据库供应商支持为特点,能够简化开发流程,提高代码质量。作为一个开源项目,它鼓励社区参与,促进其持续发展,为开发者提供了更多的选择和便利。
MySQL Connector/J 5.1.47 是一个用于Java应用程序与MySQL数据库进行连接的重要组件。它是MySQL官方提供的JDBC(Java Database Connectivity)驱动程序,允许Java开发者通过编写Java代码来执行SQL语句,管理和操作...