3

我正在运行 MariaDB 5.5.56 版并且似乎遇到了一个错误: FOUND_ROWS() 在返回零行的 SELECT 之后返回“1”。

根据错误报告 83110,MySQL 从 5.7.15 版开始就有这个问题,但似乎是一个已解决的问题,所以我认为它已修复。但是,我不确定 MySQL 和 MariaDB 版本号如何关联,或者对 MySQL 的修复是否适用于 MariaDB。

我的发行版的软件包包括 MariaDB 5.5.56 作为可用的最新版本。

难道我做错了什么?为什么前一个查询返回零结果时 FOUND_ROWS 返回 1?(是的,我在前面的查询中确实包含了 SQL_CALC_FOUND_ROWS 语句。

例子:

SELECT SQL_CALC_FOUND_ROWS * FROM table1
    WHERE field = 'something that would not match any records' LIMIT 5;
SELECT FOUND_ROWS() as count_of_rows;

-- count_of_rows = 1

这可能是同一个错误,只是在 MariaDB 中未修补,还是您认为我做错了什么?

谢谢!

4

1 回答 1

1

MariaDB 5.5 与 MySQL 5.7 匹配(包括我认为的所有错误)。MariaDB 使用 JIRA ( https://jira.mariadb.org/ ),您可以看到 SQL_CALC_FOUND_ROWS 的一些不同错误已得到解决。

我在 MariaDB 10.3(当前的 GA 版本)上进行了尝试,并创建了一些示例模式:

create table foo (id integer primary key, name varchar(50));

并插入了几行:

insert into foo(id, name) values (1, 'Bob');
insert into foo(id, name) values (2, 'Chris');
insert into foo(id, name) values (3, 'David');
insert into foo(id, name) values (4, 'Esther');
insert into foo(id, name) values (5, 'Fred');
insert into foo(id, name) values (6, 'Ginger');

并且查询对我有用: select sql_calc_found_rows * from foo where name = 'x' limit 5;

SELECT FOUND_ROWS() as count_of_rows;
+---------------+
| count_of_rows |
+---------------+
|             0 |
+---------------+
1 row in set (0.010 sec)
于 2019-03-19T22:53:12.863 回答