我的查询返回与此类似的结果。
id date
510010 12/09/2013
510010 10/09/2013
510010 05/09/2013
510010 14/09/2013
510012 14/09/2013
510012 10/09/2013
有没有办法可以让我的查询只为每个不同的ID选择最接近今天的日期?
预期结果。
510010 12/09/2013
510010 10/09/2013
510012 10/09/2013
谢谢, 克里斯
答案 0 :(得分:0)
如果您有一个名为[YourTable]的表格,其中包含数据......
id date
------ ----------
510010 2013-09-12
510010 2013-09-10
510010 2013-09-05
510010 2013-09-14
510012 2013-09-14
510012 2013-09-10
...然后您可以在Access ...
中创建名为[CalculateDaysAway]的已保存查询SELECT
[id],
[date],
Abs(DateDiff("d", [date], Date()) AS DaysAway
FROM YourTable
...(在2013-09-11运行时)返回
id date DaysAway
------ ---------- --------
510010 2013-09-12 1
510010 2013-09-10 1
510010 2013-09-05 6
510010 2013-09-14 3
510012 2013-09-14 3
510012 2013-09-10 1
现在,您可以使用该查询作为查询的基础,以返回最接近的日期...
SELECT
CalculateDaysAway.[id],
CalculateDaysAway.[date]
FROM
CalculateDaysAway
INNER JOIN
(
SELECT
[id],
MIN(DaysAway) AS MinOfDaysAway
FROM CalculateDaysAway
GROUP BY [id]
) AS MinDays
ON CalculateDaysAway.[id] = MinDays.[id]
AND CalculateDaysAway.DaysAway = MinDays.MinOfDaysAway
...(在2013-09-11运行时)返回
id date
------ ----------
510010 2013-09-12
510010 2013-09-10
510012 2013-09-10