使用PHP将MySQL查询结果显示到表中

时间:2012-04-11 18:39:11

标签: php mysql html sql

这是一个时间表,它的作用是显示前一天的时间表以及谁预订了每个时段(这是一个广播电台。)

目前它显示按时间顺序预订了每个插槽的人,但我希望它能说出每个结果旁边的时间。查询输出24行(从午夜到23:00)和每个插槽旁边我想说的(00:00,01:00,02:00,03:00~21:00,22 :00等等。)

这是我目前的代码:

<?php 
include("../config.php");

#// Timetable Clearup Variabls
$yesterday = strtotime('yesterday');
$yesterdow = date('l',$yesterday);

echo "<table width=\"580px\" class=\"board\" border=\>";

$order = "SELECT * FROM timetable WHERE day = '$yesterdow'";
$result = mysql_query($order);

// Error checking
if (!$result) {
  // output error, take other action
}
else {
  while ($row=mysql_fetch_array($result)){
     // Append all results onto an array
     $rowset[] = $row;
  }
}
    foreach ($rowset as $row) {
  echo "<tr><td>" . htmlspecialchars($row['username']) . "</td></tr>";
}



?> 

你能帮忙吗?

2 个答案:

答案 0 :(得分:1)

我认为我们在一个非常简单的问题上看起来都太过刻苦了。您已在查询中使用SELECT *,因此您已经从表中获取了所有三列。所以现在,您需要做的就是在表格的每一行添加另一个单元格。

echo "<tr><td>" . htmlspecialchars($row['username']) . "</td><td>" . htmlspecialchars($row['time']) . "</td></tr>";

为了确保以正确的顺序提取行,您应该在查询中添加ORDER BY

SELECT * FROM timetable WHERE day = '$yesterdow' ORDER BY time

如果您未指定ORDER BY条款,则无法保证以任何特定顺序获得结果。

最后一件事是,你不必要地循环两次。摆脱foreach循环并将回声直接放在while循环中。

答案 1 :(得分:0)

试试这个:

foreach ($rowset as $row) {
echo "<tr><td>" . htmlspecialchars($row['username']) . htmlspecialchars($row['time'])"</td></tr>";