Вот решение для SQL Server.Идея состоит в том, чтобы использовать коррелированный подзапрос для определения минимального RecordTime
для каждого года и месяца.Должно быть легко перевести эту идею на ваш вкус СУБД.
WITH Data AS (
SELECT CONVERT(DATETIME, '1-May-2011 01:00:00') AS RecordTime, 1.23 AS FormattedValue
UNION ALL SELECT CONVERT(DATETIME, '1-May-2011 01:12:34'), 0.99
UNION ALL SELECT CONVERT(DATETIME, '1-May-2011 23:59:59'), 2.34
UNION ALL SELECT CONVERT(DATETIME, '2-May-2011 00:11:22'), 4.56
)
SELECT D1.*
FROM Data D1
WHERE D1.RecordTime = (SELECT MIN(RecordTime)
FROM Data D2
WHERE YEAR(D2.RecordTime) = YEAR(D1.RecordTime)
AND MONTH(D2.RecordTime) = MONTH(D1.RecordTime))
Редактировать: Если ваш набор данных большой, то присоединение к подзапросу должно быть значительно быстрее, но может быть сложнеечтобы перевести на ваш вкус СУБД:
SELECT D1.*
FROM Data D1
INNER JOIN (
SELECT MIN(D2.RecordTime) AS FirstMonthlyRecordTime
FROM Data D2
GROUP BY YEAR(D2.RecordTime), MONTH(D2.RecordTime)
) AS SubQuery
ON D1.RecordTime = SubQuery.FirstMonthlyRecordTime
Редактировать 2: Следующий код является стандартной версией SQL-92 моего первого запроса выше (проверено на MySQL):
SELECT T1.RecordTime, T1.FormattedValue
FROM CDBHistoric T1
WHERE T1.RecordTime = (SELECT MIN(T2.RecordTime)
FROM CDBHistoric T2
WHERE EXTRACT(YEAR FROM T1.RecordTime) = EXTRACT(YEAR FROM T2.RecordTime)
AND EXTRACT(MONTH FROM T1.RecordTime) = EXTRACT(MONTH FROM T2.RecordTime))