0

我有这个mysql表:

+--------------------+---------+-------+
|      date          | query   | count |
|--------------------+---------+-------|
|2012-11-18 09:52:00 | Michael |   1   |
|2012-11-18 10:47:10 |  Tom    |   2   |
|2012-11-17 15:02:12 |  John   |   1   |
|2012-11-17 22:52:10 |  Erik   |   3   |
|2012-11-16 09:42:01 |  Larry  |   1   |
|2012-11-16 07:41:33 |  Kate   |   1   |
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

等等。我可以通过以下代码简单地获取结果并按日期对它们进行排序:

$queries = mysql_query("SELECT * FROM my_tables ORDER BY date DESC LIMIT 20"); 
while($row = mysql_fetch_array($queries)){
    echo "Name ".$row['query']."";
}

但是如何显示按特定日期排序的表中的元素,如下所示:

In 2012-11-18:
Michael
Tom

In 2012-11-17:
John
Erik

In 2012-11-16:
Larry
Kate

等等。谢谢!

4

5 回答 5

2

这是 PHP 代码:

$query = mysql_query("SELECT date, query FROM table6 ORDER BY date DESC LIMIT 20");
$group_date = null;
while ($row = mysql_fetch_assoc($query)) {
    if ($group_date !== substr($row["date"], 0, 10)) {
        $group_date = substr($row["date"], 0, 10);
        echo "<h1>$group_date</h1>\n";
    }
    echo "${row['query']}<br>\n";
}

输出:

2012-11-18

汤姆

迈克尔

2012-11-17

埃里克

约翰

2012-11-16

拉里

凯特

请注意,虽然此代码按一列“分组”行,但它可以轻松扩展为按多列分组行。留作练习。

于 2012-11-18T19:22:07.643 回答
0

+1 好问题,这个问题不仅仅是如何订购查询!

我认为这可以使用GROUP_CONCATfunction来完成。当您将它们分组并用逗号分隔它们时,这将组合匹配结果。一旦你有了结果,你就可以爆炸或做任何你想做的事

http://www.w3resource.com/mysql/aggregate-functions-and-grouping/aggregate-functions-and-grouping-group_concat.php

您必须按日期转换和分组,然后 group_concat 名称。然后(在 php 或 whathaveyou 中)用逗号分解名称,并回显日期后跟每个结果的名称。

编辑看起来你想要一种 PHP 方法来解决这个问题?哎呀

于 2012-11-18T17:13:06.597 回答
-1

用这个:

SELECT * FROM my_tables WHERE date > "2012-11-16" ORDER BY date LIMIT 4
于 2012-11-18T17:08:04.283 回答
-1

试试 WHERE 语句:

   select * from my_table where date_column > "2012-11-18 00:00:00" and date_column < "2012-11-18 23:59:59" order by date_column
于 2012-11-18T17:11:48.563 回答
-1

关于什么

 SELECT * FROM my_tables GROUP BY YEAR(date), MONTH(date), DAY(date) ORDER BY date DESC LIMIT 20
于 2012-11-18T17:16:47.213 回答