1

当 Job 表没有行时,以下代码会导致异常。

public List<Job> getAll(int currentPage, int pageSize) {
    return this.sessionFactory.getCurrentSession()
        .createCriteria(Job.class).addOrder(Order.asc("id"))
        .setFirstResult(currentPage * pageSize).setMaxResults(pageSize)
        .setFetchSize(pageSize).list();
}

我正在使用 SQL Server 和 JTDS 驱动程序。

我得到的错误是

java.sql.SQLException: ResultSet may only be accessed in a forward direction.
 net.sourceforge.jtds.jdbc.JtdsResultSet.checkScrollable(JtdsResultSet.java:319)
 net.sourceforge.jtds.jdbc.JtdsResultSet.absolute(JtdsResultSet.java:716)
 org.apache.commons.dbcp.DelegatingResultSet.absolute(DelegatingResultSet.java:335)
 org.hibernate.loader.Loader.advance(Loader.java:1469)
 org.hibernate.loader.Loader.getResultSet(Loader.java:1783)
 org.hibernate.loader.Loader.doQuery(Loader.java:662)
 org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:224)
 org.hibernate.loader.Loader.doList(Loader.java:2211)
 org.hibernate.loader.Loader.listIgnoreQueryCache(Loader.java:2095)
 org.hibernate.loader.Loader.list(Loader.java:2090)
 org.hibernate.loader.criteria.CriteriaLoader.list(CriteriaLoader.java:95)
 org.hibernate.impl.SessionImpl.list(SessionImpl.java:1569)
 org.hibernate.impl.CriteriaImpl.list(CriteriaImpl.java:283)
4

3 回答 3

2

该问题与尝试分页空表有关。删除这些:
.setFirstResult(currentPage * pageSize).setMaxResults(pageSize)
.setFetchSize(pageSize)
你应该能够毫无问题地查询空表。如果要对数据进行分页,请先运行常规查询,然后在知道有要分页的数据后使用查询对数据进行分页。

于 2010-09-13T07:34:34.133 回答
2

将以下属性添加到 persistence.xml 为我解决了这个问题(jboss7,hibernate4)

<property name="hibernate.jdbc.use_scrollable_resultset" value="false" />

改变方言的替代解决方案(我没有检查) - https://forum.hibernate.org/viewtopic.php?p=2452163

于 2013-02-22T05:05:03.827 回答
0

我遇到了同样的问题,在环顾了一会后,一位同事建议我改变休眠方言:

org.hibernate.dialect.SQLServerDialect

对此

org.hibernate.dialect.SQLServer2005Dialect

它解决了我的问题。

发布只是为了让人们检查他们的方言。

于 2013-07-31T01:02:34.323 回答