Eclipselink ScrollableCursor在第二次next()调用失败

时间:2015-08-25 13:15:32

标签: jpa eclipselink scrollableresults

我正在尝试使用ScrollableCursor将系统的所有用户加载到内存中。 我有这样的代码:

    Query findUsersQuery
            = entityManager.createNamedQuery(UserEntity.QUERY_ALL_USERS, UserEntity.class);
    findUsersQuery.setHint(QueryHints.SCROLLABLE_CURSOR, Boolean.TRUE);
    findUsersQuery.setHint(QueryHints.CURSOR_PAGE_SIZE, bulkSize);
    findUsersQuery.setMaxResults(maxInitialCacheSize);

    ScrollableCursor scrollableCursor = (ScrollableCursor) findUsersQuery.getSingleResult();
    int leftSize = scrollableCursor.size();
    while (scrollableCursor.hasNext()) {

        int nextSize = leftSize > bulkSize ? bulkSize : leftSize;
        List subscriberPrefs = scrollableCursor.next(nextSize);
        leftSize -= nextSize;
        //... Result list processing

    }

查询为:SELECT s FROM UserEntity u order by u.userId

当scrollableCursor.next(nextSize)时,结果表的大小为100;叫,我得到以下异常:

org.eclipse.persistence.exceptions.DatabaseException
Internal Exception: java.sql.SQLRecoverableException: Closed Resultset
Error Code: 17010
    at org.eclipse.persistence.exceptions.DatabaseException.sqlException(DatabaseException.java:324)
    at org.eclipse.persistence.internal.databaseaccess.DatabaseAccessor.cursorRetrieveNextRow(DatabaseAccessor.java:447)[215:org.eclipse.persistence.core:2.4.1.v20121003-ad44345]
    at org.eclipse.persistence.queries.ScrollableCursor.retrieveNextObject(ScrollableCursor.java:563)[215:org.eclipse.persistence.core:2.4.1.v20121003-ad44345]
    at org.eclipse.persistence.queries.ScrollableCursor.loadNext(ScrollableCursor.java:411)[215:org.eclipse.persistence.core:2.4.1.v20121003-ad44345]
    at org.eclipse.persistence.queries.ScrollableCursor.next(ScrollableCursor.java:437)[215:org.eclipse.persistence.core:2.4.1.v20121003-ad44345]
    at org.eclipse.persistence.queries.ScrollableCursor.next(ScrollableCursor.java:459)[215:org.eclipse.persistence.core:2.4.1.v20121003-ad44345]

在调用next(10)时,正常加载第一行,第二行发生异常。我不知道为什么。谁能说我怎么能避免这个错误?

0 个答案:

没有答案