1

这是我用于查询的 php 脚本:

    $query="SELECT f.EVENT, 
    f.LOCATION, 
    f.DOE, 
    f.CATEGORY, 
    f.LOGLOC, 
    f.LOGDOE, 
    f.LOGCAT, 
    ((( f.NUMOFTIMESLOC * ( Log(f.LOGLOC) ) ) + 
                                             ( f.NUMOFTIMESDOE * ( Log(f.LOGDOE) ) ) + ( 
                                           f.NUMOFTIMESCAT * (Log(f.LOGCAT))))) AS FINALRANK 
                                FROM   (SELECT E.EVENT, 
                                               ED.LOCATION, 
                                               ED.DOE, 
                                               ED.CATEGORY, 
                                               ( ( ED.NUMOFDATASET / ED.NUMOFTIMESLOC ) * 100 ) AS LOGLOC, 
                                               ( ( ED.NUMOFDATASET / ED.NUMOFTIMESDOE ) * 100 ) AS LOGDOE, 
                                               ( ( ED.NUMOFDATASET / ED.NUMOFTIMESCAT ) * 100 ) AS LOGCAT, 
                                               ED.NUMOFTIMESLOC, 
                                               ED.NUMOFTIMESDOE, 
                                               ED.NUMOFTIMESCAT 
                                        FROM   EVENT E, 
                                               EVENTDETAIL ED 

                                        WHERE  E.EVENTID = ED.EVENTID 
                                               AND ED.LOCATION = 'Liverpool' 
                                               AND ED.CATEGORY = 'Concerts') f ORDER BY FINALRANK";
                                $result=mysql_query($query);
                                $num=mysql_numrows($result);
                                mysql_close();
                                $i=0;
                                if(!$num){
                                    echo ("No Results");
                                }
                                else{
                                    while ($i < $num) {
                                        $eventid=mysql_result($result,$i,"eventid");
                                        echo $eventid;
                                        echo"<br>";
                                        $i++;
                                    }
                                }

当此查询在命令控制器中运行时,它工作正常并为查询打印 2 个结果,但与 PHP 一起使用时,它只返回“无结果”。请帮忙!

4

3 回答 3

4
  • 你的问题是你mysql_close(); 在输出结果之前关闭了连接

删除该 lignemysql_close();并使其出现在您的最后一个结果中。

  • 并确保将其更改mysql_numrowsmysql_num_rows
于 2013-04-01T14:39:47.943 回答
3

我认为这是因为mysql_numrows(). 这应该是mysql_num_rows()。在这里改变它。

$num=mysql_num_rows($result);
于 2013-04-01T14:34:53.677 回答
0
$num=mysql_numrows($result);  

那是错误的函数名称,它是

$num=mysql_num_rows($result);

mysql_num_rows

这样你$num就不会是假的,你也不会看到“没有结果”的消息;目前由于那个错误,它被设置为假,因此你的 if 总是触发

于 2013-04-01T14:35:41.767 回答