2012-04-12 45 views
0

我目前有以下使用MySQL的PHP​​文件,它应该返回结果从00:00到23:00(这是一个时间表),但它只返回01: 00〜23:00:PHP中的MySQL查询不返回真实结果

<?PHP 
include("../panel/config.php"); 
#// Timetable Clearup Variabls 

$yesterday = strtotime('yesterday'); 
$yesterdow = date('l',$yesterday); 
$order = "SELECT * FROM timetable WHERE day = '$yesterdow' ORDER BY time LIMIT 0 , 30"; 
$result = mysql_query($order); 
$yesterdayd = date('F jS, Y', time()-86400); 

    //SET XML HEADER 
    header('Content-type: text/xml'); 

    //CONSTRUCT RSS FEED HEADERS 
    $output = '<rss version="2.0">'; 
    $output .= '<channel>'; 
    $output .= "<title>Timetable - {$yesterdayd} </title>"; 
    $output .= '<description>Timetable.</description>'; 
     $output .= '<link>http://www.site.com</link>'; 
    while ($row = mysql_fetch_array($result)) { 
    //BODY OF RSS FEED 

    $output .= "<item><title>Timetable - {$yesterdayd}</title> 
    <description>"; 
while ($row=mysql_fetch_array($result)) 
{ 
     $rowset[] = $row; 
    //BODY OF RSS FEED 
    $output .= htmlspecialchars($row['time']) . " " . htmlspecialchars($row['username']) . "<br/>"; 
} 
$output .= '</description></item> '; 
} 
    //CLOSE RSS FEED 
    $output .= '</channel>'; 
    $output .= '</rss>'; 

    //SEND COMPLETE RSS FEED TO BROWSER 
$filename = "timetable.xml"; 

       if (!$handle = fopen($filename, 'w')) { 
      echo "Cannot open file ($filename)"; 
      exit; 
      } 

      // Write $somecontent to our opened file. 
      if (fwrite($handle, $output) === FALSE) { 
      echo "Cannot write to file ($filename)"; 
      exit; 
      } 

      if (fwrite($handle, $total) === FALSE) { 
      echo "Cannot write to file ($filename)"; 
      exit; 
      } 

      echo "Success, wrote {$content}{$total} to file ($filename)"; 

      fclose($handle); 


?> 

任何人都可以提供一些线索

+0

这是功课吗?有人发布类似的东西... http://stackoverflow.com/questions/10111956/display-results-from-mysql-query-into-table-using-php/10112101#10112101 – 2012-04-12 00:37:19

+0

什么是'$ nightsdow'在你的SQL查询中? – Lion 2012-04-12 00:37:20

+0

您的数据库表是否包含要作为您的假设返回的适当值? – Lion 2012-04-12 00:41:07

回答

1

您将要覆盖的第一个结果是由于双while循环。

while ($row = mysql_fetch_array($result)) { 
    //BODY OF RSS FEED 

    $output .= "<item><title>Timetable - {$yesterdayd}</title><description>"; 
    while ($row=mysql_fetch_array($result)) 
    { 
     // First $row result is now overwritten before you used it 
     // ... 

此外,您可能需要使用date('Y-m-d')而不是date('l')。我不确定你的日期栏包含哪些内容,但date('l')返回上周和周五5周前的星期二和星期二之间不区分的日期的名称。

您只需要一个while($row = mysql_fetch_array($result))而不是两个。

+0

当我删除while循环中的一个时,它会导致内容被单独封装在中,而当我使用两个while循环时把所有返回的内容放在一个<description>内容全部</ description> Shoier 2012-04-12 00:53:41

+0

嗯,我不确定你想要的最终输出是什么,但你可能需要做一些重新格式化后删除一个while循环。我所知道的是,在发布的代码中,您正在失去第一个结果,内部while循环正在完成所有工作。除了丢失一个结果并将所有内部循环结果打印在一个元素中外,其他什么也不做。 – drew010 2012-04-12 00:56:14