SQL Продолжайте счет, после внутреннего соединения - PullRequest
3 голосов
/ 02 апреля 2020

Я работаю с локальным mysql сервером и имею две таблицы.

Таблица A:

ID | Name 
1    Joe
2    Bob
3    John

Таблица B:

ID |    DATE    |  Name_ID | Point
1    2010-01-01       1       1
2    2011-01-01       1       1
3    2013-01-01       1      -1
4    2010-01-01       2      -1
5    2012-01-01       2      -1
6    2013-01-01       2      -1
7    2014-01-01       2       1

Для каждого идентификатора в Таблице A я пытаюсь получить максимальную дату

  1. и
  2. текущий счет их очков. (даты и точки указаны в таблице B).

Требуется результат:

Name | Latest_Date | Point_total
John      NULL         NULL
Joe     2013-01-01      1
Bob     2014-01-01     -2

Пока у меня есть этот запрос:

SELECT DISTINCT a.Name, b.Date, SUM(b.point) OVER (PARTITION BY b.Name_ID) Point_total FROM 
TableA a 
LEFT OUTER JOIN TableB b 
ON a.ID = b.Name_ID 
INNER JOIN  (
SELECT b.Name_ID, MAX(b.Date) Latest_Date 
FROM TableB b GROUP BY b.Name_ID ) m 
ON (m.Latest_Date = b.Date or (b.Date is NULL)) AND 
(b.Name_ID = m.Name_ID OR (b.Name_ID is NULL)) 
ORDER BY Name_ID;

В итоговой таблице выводится правильная максимальная дата, но промежуточная сумма учитывает только точку ввода с максимальной датой.

Что мне здесь не хватает?

Ответы [ 3 ]

2 голосов
/ 02 апреля 2020

Это запрос агрегации:

select a.name, max(b.date) latest_date, sum(b.point) point_total
from a
left join b on b.name_id = a.id
group by a.id, a.name
2 голосов
/ 02 апреля 2020

Это выглядит как агрегация:

SELECT a.Name, MAX(b.Date), SUM(b.point) as Point_total
FROM TableA a LEFT OUTER JOIN
     TableB b 
     ON a.ID = b.Name_ID 
GROUP BY a.name
1 голос
/ 02 апреля 2020
SELECT A.Name, MAX(B.Date) as Max_Date, SUM(b.point) as Total_Points
FROM TableA as A
    LEFT JOIN TableB as B 
    ON A.ID = B.Name_ID 
GROUP BY A.name
...