6

我将如何显示在过去一小时内具有时间戳值的行?

这是我现在所拥有的,它显示了最新的行,由于限制,只有 3 行。

$query5= mysql_query("SELECT * FROM  `made_orders` ORDER by id DESC LIMIT 0,3");



    WHILE($datarows5 = mysql_fetch_array($query5)):

    $name4 = $datarows5['Name'];
    $phone4 = $datarows5['Phone'];
    $entree4 = $datarows5['Entree'];
    $side14 = $datarows5['Side 1'];
    $side24 = $datarows5['Side 2'];
    $drink4 = $datarows5['Drink'];
    $totalcost4 = $datarows5['Total Cost'];
    $ip4 = $datarows5['Ip'];
    $id4 = $datarows5['id'];
    $time4 = $datarows5['timestamp'];

    echo "<iframe src=\"creatmeal-data.php?id={$id4}\" width=\"430px\" style=\"border:0px\" height=\"350px\"/></iframe>";

endwhile; ?>

在我上面的代码中,每次找到一行时,它都会回显一个 iframe。我将如何编辑查询以使用我的时间戳列仅显示一小时内的最新消息。

在此先感谢您的帮助!

编辑:这是我的时间戳列的样子:http: //img856.imageshack.us/img856/4135/columnk.png

4

2 回答 2

19

您当前的查询获取三个最近的订单,无论它们是否是在过去一小时内创建的。

使用此解决方案:

SELECT *
FROM made_orders
WHERE timestamp >= NOW() - INTERVAL 1 HOUR
ORDER BY timestamp DESC
LIMIT 3

这将在最后一小时内获得最多三个订单。如果最近一小时内只有一个订单,它只会选择一行。

于 2012-07-08T21:51:18.383 回答
1

SELECT * FROM made_ordersORDER by id WHERE UNIX_TIMESTAMP( yourTimestampColumn) > UNIX_TIMESTAMP() - 60*60

于 2012-07-08T21:40:00.140 回答