Ответ Is7aq является правильным в соответствии с вашим вопросом, но будет работать только на MySQL.Также не учитывается возможность того, что больше чем один клиент купил больше всего за данный год, хотя я признаю, что это не было ограничением, перечисленным в первоначальном вопросе.Кроме того, это огромный удар по производительности для перекрестных объединений, просто используя запятые, когда ваши базы данных становятся достаточно большими, поэтому почти всегда лучше использовать INNER или OUTER объединения и указывать условие объединения.В любом случае, сделал это как упражнение, и вот что у меня было.Вероятно, это может быть лучше оптимизировано:
CREATE TABLE #Client (
Client_Id int not null,
Name varchar(100) not null
)
INSERT INTO #Client VALUES (1, 'Client 1')
INSERT INTO #Client VALUES (2, 'Client 2')
INSERT INTO #Client VALUES (3, 'Client 3')
CREATE TABLE #Orders (
Order_Id int not null,
Client_Id int not null,
Order_Total int not null,
Date datetime not null
)
-- Customer 1: total=105
INSERT INTO #Orders VALUES (1, 1, 55, '1/1/2011')
INSERT INTO #Orders VALUES (2, 1, 50, '1/1/2011')
INSERT INTO #Orders VALUES (3, 1, 45, '1/1/2010') -- test removal of invalid dates
-- Customer 2: total=120
INSERT INTO #Orders VALUES (4, 2, 40, '1/1/2011')
INSERT INTO #Orders VALUES (5, 2, 40, '1/1/2011')
INSERT INTO #Orders VALUES (6, 2, 40, '1/1/2011')
-- Customer 3: total=120
INSERT INTO #Orders VALUES (7, 3, 40, '1/1/2011')
INSERT INTO #Orders VALUES (8, 3, 40, '1/1/2011')
INSERT INTO #Orders VALUES (9, 3, 40, '1/1/2011')
-- control customer to test hi/lo scenarios: total=40
INSERT INTO #Orders VALUES (10, 4, 10, '1/1/2011')
INSERT INTO #Orders VALUES (11, 4, 10, '1/1/2011')
INSERT INTO #Orders VALUES (12, 4, 10, '1/1/2011')
INSERT INTO #Orders VALUES (13, 4, 10, '1/1/2011')
SELECT T.NAME,
T.OrderTotal
FROM (SELECT C.NAME,
SUM(O.ORDER_TOTAL) OrderTotal
FROM #CLIENT C
INNER JOIN #ORDERS O
ON c.CLIENT_ID = o.CLIENT_ID
WHERE YEAR(O.DATE) = 2011
GROUP BY C.NAME) as T
WHERE T.OrderTotal = (SELECT MAX(T2.OrderTotal2)
FROM (SELECT C2.NAME,
SUM(O2.ORDER_TOTAL) OrderTotal2
FROM #CLIENT C2
INNER JOIN #ORDERS O2
ON c2.CLIENT_ID = o2.CLIENT_ID
WHERE YEAR(O2.DATE) = 2011
GROUP BY C2.NAME) as T2)
GROUP BY T.Name, T.OrderTotal
DROP TABLE #Client
DROP TABLE #Orders
-- Output
-- Client 2: 120
-- Client 3: 120