У меня есть этот запрос:
SELECT p.ProductName,
dt.MaxTimeStamp,
p.Responsible
FROM Product p
LEFT JOIN (SELECT ProductID, MAX(TimeStamp) AS MaxTimeStamp
FROM StateLog
WHERE State = 0
GROUP BY ProductID, State) dt ON p.ProductID = dt.ProductID
ORDER BY p.ProductName;
Он работает, как и должно быть, но теперь мне нужно выбрать «государство» тоже.
Хитрость в том, что я хочу только Lastest «TimeStamp», где «государство» было ложным. Но теперь мне нужно «государство» для Lastest «TimeStamp».
Я попытался это:
SELECT p.ProductName, dt.State, dt.MaxTimeStamp, p.Responsible
FROM Product p
LEFT JOIN (SELECT ProductID, MAX(TimeStamp) AS MaxTimeStamp, State
FROM StateLog
WHERE State = 0
GROUP BY ProductID, State) dt ON p.ProductID =dt.ProductID
ORDER BY p.ProductName;
Но это не сработало, потому что он дал мне «государство» для Lastest «TimeStamp».
Поэтому я надеюсь, что есть некоторые умные головы, которые там могут помочь мне. Я предполагаю, что это либо очень простым или очень трудно решить.