Я работаю с локальным 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 я пытаюсь получить максимальную дату
- и
- текущий счет их очков. (даты и точки указаны в таблице 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;
В итоговой таблице выводится правильная максимальная дата, но промежуточная сумма учитывает только точку ввода с максимальной датой.
Что мне здесь не хватает?