1

我正在运行由几个内部查询构建的非常复杂的查询。该查询在其开头包含 SQL_CALC_FOUND_ROWS。不幸的是,只能获取行数(我无法获取结果本身)。

我决定摆脱 SQL_CALC_FOUND_ROWS 并运行两个不同的查询,一个计算行数,第二个获取它们。在这种情况下,我可以检索结果,但 COUNT(*) 查询的行为很奇怪。这就是我所做的:

  1. 执行 COUNT(*) 查询
  2. mysql_query() 返回 FALSE
  3. mysql_error() 在 COUNT(*) 查询返回空字符串后直接运行

代码是:

$sqlCount = "SELECT COUNT(*) AS c FROM ... WHERE ...";
$resultCount = mysql_query($sqlCount);
echo "RESULT COUNT: " . ($resultCount === FALSE) . "<br />";//it returns 1(true)
echo mysql_error(); //it returns nothing (blank string)

另外 mysql_errno() 返回 0

对于这种奇怪的情况,你能找到任何合理的解释吗?

4

3 回答 3

1

我在您的代码中看不到任何错误。请尝试将您的 mysql_query 行更改为

 $resultCount = mysql_query($sqlCount) or die(mysql_error() ." <-- There was an error when proccessing query");

它看起来很奇怪,但可以帮助你

于 2011-08-17T11:45:49.753 回答
0

您能否填写...空白并尝试

<?php
error_reporting(E_ALL);
ini_set('display_errors', true);

$mysql = mysql_query('..', '..', '..') or die(mysql_error());
mysql_select_db('...', $mysql) or die(mysql_error($mysql));

echo '<pre>Debug: mysql_get_server_info='; var_dump(mysql_get_server_info($mysql)); echo "</pre>\n";
echo '<pre>Debug: mysql_get_client_info='; var_dump(mysql_get_client_info()); echo "</pre>\n";

$sqlCount = "SELECT COUNT(*) AS c FROM ... WHERE ...";
echo '<pre>Debug: sqlCount='; var_dump($sqlCount); echo "</pre>\n";
$resultCount = mysql_query($sqlCount, $mysql);
echo '<pre>Debug: resultCount='; var_dump($resultCount); echo "</pre>\n";
echo '<pre>Debug: mysql_error='; var_dump(mysql_error($mysql)); echo "</pre>\n";
echo '<pre>Debug: mysql_errno='; var_dump(mysql_errno($mysql)); echo "</pre>\n";

并发布输出?

于 2011-08-17T13:24:28.923 回答
0

这很奇怪,因为带有 SQL_CALC_FOUND_ROWS 的 select 子句返回行,而附加查询将返回行数。如果你使用

$result = mysql_query('SELECT SQL_CALC_FOUND_ROWS * from table');
$total = mysql_query('SELECT FOUND_ROWS()');
process $result.

你不应该有任何问题。

于 2011-08-17T12:22:42.280 回答