我一直试图让一系列嵌套循环工作,从一个表中选择数据库名称,然后查询该数据库中的选定表,并将结果相加并显示它们的数量和数据库名称。
我已经让代码工作但它一直显示:
Warning: mysql_fetch_array() expects parameter 1 to be resource, boolean given in
我已经尝试过各种可能的方法,我在网上找到了帮助,但都没有工作。
$resulta = mysql_query("SELECT dbname AF012 FROM Customer");
while($data = mysql_fetch_array($resulta))
{
$db = $data[' dbname '];
$result = null;
$result2 = mysql_query("SELECT changemade FROM $db.orders");
//looping through the results
while($row = mysql_fetch_array($result2))
{
//checking if any record is 1,2 or 3
if( ($row[‘changemade’]== 1) || ($row[‘changemade’]== 2) || ($row[‘changemade’]== 3) ) {
//if any match the if adding 1 to the counter
$counter ++;
}
}
unset($result2);
echo $db." ".$counter;
echo "<br>";
$counter = 0;
$result = null;
$result2 = null;
}
所有数据库连接都已完成且工作正常,因此它与此无关。任何帮助都会很棒。
答案 0 :(得分:4)
您需要引入错误处理,也可以简化代码。当前的失败点是查询数据库并从中获取,因此您可以将其封装到自己的函数中,这也会减少您的代码:
function mysql_query_array($query)
{
if (!$result = mysql_query($query)) {
throw new Exception(sprintf('Invalid query "%s", error: %s.', $query, mysql_error()));
}
return function () use ($result) {
return mysql_fetch_array($result);
};
}
使用这个小帮助函数,您的代码现在更紧凑,并且具有实际的错误处理:
$queryA = mysql_query_array("SELECT dbname AF012 FROM Customer");
while ($data = $queryA())
{
$counter = 0;
$queryB = mysql_query_array("SELECT changemade FROM {$data['dbname']}.orders");
while ($row = $queryB())
{
if (in_array($row['changemade'], range(1, 3))) {
$counter++;
}
}
printf("%s %s<br>\n", $db, $counter);
}
答案 1 :(得分:1)
这是由于mysql_query
在查询失败时返回false,因此您的某个查询失败并且mysql_fetch_array()
获得布尔值。尝试将$db = $data[' dbname '];
更改为$db = $data['dbname'];