首先按组顺序检索所有行?

时间:2018-01-16 18:22:28

标签: mysql sql database sqlite group-by

我有桌子,我有id和时间。

ID  |   Time
1   | 8.35 
1   | 8.40
3   | 8.43
4   | 8.45
1   | 8.50
2   | 8.52
3   | 8.54
4   | 8.55
1   | 8.57
2   | 9.01
3   | 9.05
5   | 9.06

必填结果

ID  | Time
5   | 9.06
3   | 9.05
3   | 8.54
3   | 8.43
2   | 9.01
2   | 8.52
1   | 8.57
1   | 8.50
1   | 8.40
1   | 8.35
4   | 8.55
4   | 8.45

目前我正在Select * from table group by ID order by Time DESC进行并获取

结果一:

  ID    | Time

    5   | 9.06

    3   | 9.05

    2   | 9.01

    1   | 8.57

    4   | 8.55 

然后编写第二个查询并将数据存储在列表中。

foreach value in Result one:
Select * from Table where ID = value

我想要只有一个查询,而不是编写循环。

基本问题是我要分组ID,顶级组应该是最近发生的项目。如示例1中出现很多次,但我将仅考虑分组时的最新时间。

我可以只编写一个查询来获得结果吗?

1 个答案:

答案 0 :(得分:1)

SELECT ID, Time FROM Table ORDER BY ID, Time

分组结合了匹配的行,因此您不希望进行分组,排序将它们按顺序排列,这就是您想要的,您希望所有ID按顺序排列,然后按顺序排列这些ID,所以您想按ID订购,然后按时间排序。

由于问题编辑而更新

这可以通过加入子选择

来完成
SELECT t.ID. t.Time FROM Table t
JOIN (SELECT ID, Max(Time) as Time FROM Table GROUP BY ID) ss
ON t.ID = ss.ID
ORDER BY ss.Time DESC, t.ID DESC, t.Time DESC

子选择(ss)执行您在那里的第一个查询,并将其连接到主表,让您按每个ID的最高(最长)时间排序,然后按行和本身的时间排序。请注意,所有排序都是在最终查询中完成的,子选择中的排序是无用的,因为连接将无论如何重新排序。