【发布时间】:2013-04-05 16:52:21
【问题描述】:
在 MS Access 查询中,如何对一列进行分组,然后使用最大 ID 从表中获取特定值。我知道我可以分组并使用 max 来获取最大 ID,但不知道如何获取多个最大 ID。
如果我有这样的表:
+----+------+-------+------+
| ID | Col1 | Col2 | Col3 |
+----+------+-------+------+
| 1 | a | one | 100 |
| 2 | a | two | 200 |
| 3 | a | three | 300 |
| 4 | a | four | 400 |
| 5 | a | five | 500 |
| 6 | b | one | 600 |
| 7 | b | two | 700 |
| 8 | b | three | 800 |
| 9 | b | four | 900 |
| 10 | b | one | 1000 |
| 11 | b | three | 1100 |
| 12 | b | six | 1200 |
| 13 | c | one | 1300 |
| 14 | c | two | 1400 |
| 15 | c | three | 1500 |
| 16 | c | four | 1600 |
| 17 | c | six | 1700 |
| 18 | c | three | 1800 |
| 19 | c | two | 1900 |
| 20 | c | one | 2000 |
+----+------+-------+------+
我想得到这个:
+------+------+------+-------+
| Col1 | one | two | three |
+------+------+------+-------+
| a | 100 | 200 | 300 |
| b | 1000 | 700 | 1100 |
| c | 2000 | 1900 | 1800 |
+------+------+------+-------+
当 Col1 = b 且 Col2 = 1 时,ID = 6 和 10。由于 10 较大,因此该行的值是 1000。对于表的其余部分也是如此...
我这辈子都不知道该怎么做。
【问题讨论】:
-
欢迎来到 Stack Overflow!请通过添加适当的标记(Oracle、SQL Server、MySQL 等)来指定您要定位的 RDBMS。可能有一些答案利用了不受普遍支持的语言或产品功能。此外,通过使用特定的 RDBMS 对其进行标记,您的问题可能会受到更适合回答的人的关注。
标签: sql ms-access ms-access-2007 pivot