0

我正在我的数据库中创建一个搜索,当我使用 foreach 构造来回显我的结果时,我得到“为 foreach 提供的参数无效......”。我不明白为什么会出现这个错误,因为包含我的错误的 foreach 工作正常。

if (empty($errors)){
    $results = search_results($keywords);
    $results_num = count($results);

    foreach ($results as $result){
        echo '<p> <strong>', $result['TITLE'], '</strong> </p>';
    }
} else {
    foreach($errors as $error){
        echo $error, '</br>';
    }
}

search_results 函数中关注的部分是这个

$results = "SELECT TITLE FROM occupationalinfo WHERE $where"; 
$results_num = ($results = mysql_query($results)) ? mysql_num_rows($results): 0;

if ($results_num === 0){
    return false;
}else{
    while ($results_row = mysql_fetch_assoc($results)) {
        $returned_results[] = array(
            'title' => $results_row['TITLE']
        );      
    }
}

我还是编程新手,所以我知道是否有一些我可能错过或不太明白的东西。我将不胜感激任何提示或建设性的批评。

4

2 回答 2

5
if ($results_num === 0){
    return false;
}

我敢打赌这正在执行,所以它正在返回false。您不能foreach申请false. 也许你应该return array(),或者只是检查false

$results = search_results($keywords);
if ($results !== false) {
    $results_num = count($results);

    foreach ($results as $result){
        echo '<p> <strong>',$result['TITLE'],'</strong> </p>';
    }
}
于 2012-10-10T19:34:22.793 回答
0

试试php函数is_array()

if (empty($errors)){
           $results = search_results($keywords);
            if(is_array($results)){
               foreach ($results as $result){
                 echo '<p> <strong>'. $result['TITLE'] .'</strong></p>';
               }
            } else {
                echo "<p> <strong>empty</strong></p>";
            }
    } 

或者

 if (empty($errors)){
        $results = search_results($keywords);
        if(is_array($results)){
             $results_num = count($results);
             foreach ($results as $result){
               echo '<p> <strong>'. $result['TITLE']. '</strong> </p>';
             }
        }        
    } else {
        foreach($errors as $error){
            echo $error, '</br>';
        }
    }
于 2012-10-10T19:45:52.503 回答