我有桌子,我有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中出现很多次,但我将仅考虑分组时的最新时间。
我可以只编写一个查询来获得结果吗?
答案 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的最高(最长)时间排序,然后按行和本身的时间排序。请注意,所有排序都是在最终查询中完成的,子选择中的排序是无用的,因为连接将无论如何重新排序。