Запрос наибольшего числа n на группу, включая строки, в которых нет n - PullRequest
0 голосов
/ 20 июня 2020

Я знаю, что это распространенный вопрос, но я не смог найти ответа на эту c проблему:

У меня есть две таблицы:

+--------------+     +-------------------------------+
| temp1        |     | temp2                         |
+----+---------+     +----+----+---------------------+
| id | name    |     | id | fk | ts                  |
+----+---------+     +----+--------------------------+
| 1  | first   |     | 1  | 1  | 2020-06-19 23:56:46 | 
| 2  | second  |     | 2  | 1  | 2020-06-19 22:56:46 | 
| 3  | third   |     | 3  | 2  | 2020-06-19 21:56:46 | 
+----+---------+     | 4  | 2  | 2020-06-19 20:56:46 | 
                     +----+--------------------------+

Чтобы получить для каждой записи в temp1 соответствующую запись из temp2 с новейшей меткой времени, я выполняю следующий запрос:

SELECT 
    t1.id AS id,
    t1.name AS name,
    t2.ts AS ts
FROM
    (temp2 t2
    JOIN temp1 t1)
WHERE
    t2.ts = (SELECT MAX(t3.ts)
        FROM
            temp2 t3
        WHERE
            t2.fk = t3.fk)
        AND t2.fk = t1.id

Это приводит к:

+----+--------+---------------------+
| id | name   | ts                  |
+----+------------------------------+
| 1  | first  | 2020-06-19 23:56:46 | 
| 2  | second | 2020-06-19 21:56:46 | 
+----+------------------------------+

Возможно ли чтобы изменить этот запрос, чтобы включить строки из temp1, которые не имеют соответствующего значения в temp2?

Желаемый результат будет:

+----+--------+---------------------+
| id | name   | ts                  |
+----+------------------------------+
| 1  | first  | 2020-06-19 23:56:46 | 
| 2  | second | 2020-06-19 21:56:46 | 
| 3  | third  | NULL                | 
+----+------------------------------+

Ответы [ 2 ]

0 голосов
/ 20 июня 2020

Самый простой способ сделать это - использовать коррелированный подзапрос в списке SELECT:

SELECT t1.*,
  (SELECT MAX(t2.ts) FROM temp2 t2 WHERE t2.fk = t1.id) ts
FROM temp1 t1

См. demo . Результатов:

| id  | name   | ts                  |
| --- | ------ | ------------------- |
| 1   | first  | 2020-06-19 23:56:46 |
| 2   | second | 2020-06-19 21:56:46 |
| 3   | third  |                     |
0 голосов
/ 20 июня 2020

Использовать оконные функции:

SELECT t1.id, t1.name, t2.ts
FROM t1 LEFT JOIN
     (SELECT t2.*, ROW_NUMBER() OVER (PARTITION BY t2.fk ORDER BY t2.ts DESC) as seqnum
      FROM temp2 t2
     ) t2
     ON t2.fk = t1.id AND seqnum = 1;
...