1

我的数据库中有 3 条记录(用于测试目的),我使用 SQL_CALC_FOUND_ROWS 返回行数和 LIMIT 来收集分页结果。

SELECT SQL_CALC_FOUND_ROWS * FROM contacts WHERE contacts.organizationId = :organizationId LIMIT 0, 1

我正在使用 Spring 进行数据库业务登录。

public List<Contact> findAll(int organizationId, int rowStart, int rowAmount, final boolean deep) {
    final HashMap<String, Object> namedParameters = new HashMap<String, Object>();
    namedParameters.put("organizationId", String.valueOf(organizationId));
    namedParameters.put("rowStart", rowStart);
    namedParameters.put("rowAmount", rowAmount);
    final NamedParameterJdbcTemplate namedParameterJdbcTemplate = new NamedParameterJdbcTemplate(dataSource);
    DataSourceTransactionManager transactionManager = new DataSourceTransactionManager(dataSource);
    TransactionTemplate transactionTemplate = new TransactionTemplate(transactionManager);

    List<Contact> contactList = transactionTemplate.execute(new TransactionCallback<List<Contact>>() {

        @Override
        public List<Contact> doInTransaction(TransactionStatus status) {
            SqlRowSet result = namedParameterJdbcTemplate.queryForRowSet(SQL_FIND_ALL_BY_ORGANIZATION_ID, namedParameters);
            int count = namedParameterJdbcTemplate.queryForInt("SELECT FOUND_ROWS()", (HashMap<String, ?>) null);
            System.out.println(count);
            List<Contact> contactList = mapContact(result, deep);
            if(contactList.size() > 0) {
                return contactList;
            } else {
                return null;
            }
        }

    });
    return contactList;
}

无论我做什么,当我在表中只有 3 行时,计数都会返回 6。事实上,无论结果集中有多少行,它都会返回 6。为什么数量翻倍,我做错了什么?

更新

我最终使用了这个:

int count = namedParameterJdbcTemplate.queryForInt("SELECT Count(*) FROM contacts WHERE contacts.organizationId = :organizationId", namedParameters);

基本上和我之前做的一样,但是 SQL 改变了一点。我现在使用 count 而不是 SQL_CALC,我认为这会导致两个单独的查询,但对于 Spring,它似乎是唯一的方法。

4

2 回答 2

0

它看起来像使用SqlRowSet. 也许 JDBC 驱动程序会在内部发出一些查询来支持它。

如果您不需要特定功能,SqlRowSet最好使用更传统的方法。例如,最好使用RowMapper<Contact>to 查询List<Contact>.

于 2012-04-24T13:11:15.357 回答
0

这是一个有点旧的帖子,但是由于我在研究时遇到它并且这并不能完全满足我的需求,一旦我弄清楚了,我就把所有东西都写在这里了。https://www.contradodigital.com/2018/01/06/how-to-use-sql_calc_found_rows-and-found_rows-with-limit-and-offset-in-a-mysql-query-using-java-and-数据库/

本质上,要使 MySQL FOUND_ROWS() 工作,您需要在与第一个查询相同的 JDBC 连接中运行 FOUND_ROWS()。这将确保返回的数据是准确的。

于 2018-01-06T14:12:34.870 回答