0

我的表如下所示:

id  | user_id | period_id | completed_on
----------------------------------------
1   | 1       | 1         | 2010-01-01
2   | 2       | 1         | 2010-01-10
3   | 3       | 1         | 2010-01-13
4   | 1       | 2         | 2011-01-01
5   | 2       | 2         | 2011-01-03
6   | 2       | 3         | 2012-01-13
... | ...     | ...       | ...

我只想选择最新的用户期间条目,记住用户不会都有相同的期间条目。

本质上(假设我只有上表)我想得到这个:

id  | user_id | period_id | completed_on
----------------------------------------
3   | 3       | 1         | 2010-01-13
4   | 1       | 2         | 2011-01-01
6   | 2       | 3         | 2012-01-13

以下两个查询总是导致选择第一个 user_id 出现,而​​不是最新的(因为排序发生在从我理解的行中选择之后):

SELECT
    DISTINCT user_id,
    period_id,
    completed_on
FROM my_table
ORDER BY
    user_id ASC,
    period_id DESC

SELECT *
FROM my_table
GROUP BY user_id
ORDER BY
    user_id ASC,
    period_id DESC
4

2 回答 2

2

似乎这应该使用MAX和子查询:

SELECT t.Id, t.User_Id, t.Period_Id, t.Completed_On
FROM my_table t
   JOIN (SELECT Max(completed_on) Max_Completed_On, t.User_Id
         FROM my_table
         GROUP BY t.User_ID
         ) t2 ON
      t.User_Id = t2.User_Id AND t.Completed_On = t2.Max_Completed_On

但是,如果您可能有多个记录,其中每个用户的 completed_on 日期相同,那么这可能会返回多个记录。根据您的需要,可能在您的子查询中添加一个 MAX(Id) 并加入它会起作用。

于 2013-03-26T18:34:31.650 回答
0

尝试这个:

SELECT t.Id, t.User_Id, t.Period_Id, t.Completed_On
FROM table1 t
JOIN (SELECT Max(completed_on) Max_Completed_On, t.User_Id
FROM table1 t
GROUP BY t.User_ID) t2 ON t.User_Id = t2.User_Id AND t.Completed_On = t2.Max_Completed_On

在这里演示

于 2013-03-26T18:38:23.527 回答