这是一个时间表,它的作用是显示前一天的时间表以及谁预订了每个时段(这是一个广播电台。)
目前它显示按时间顺序预订了每个插槽的人,但我希望它能说出每个结果旁边的时间。查询输出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>";
}
?>
你能帮忙吗?
答案 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>";