Możesz generować sekwencje danych za pomocą generate_series()
funkcja:
SELECT to_char(generate_series(min, max, '1 month'), 'Mon-YY') AS "Mon-YY"
FROM (
SELECT date_trunc('month', min(startdate)) AS min,
date_trunc('month', max(startdate)) AS max
FROM a) sub;
To generuje wiersz na każdy miesiąc, w ładnym formacie. Jeśli chcesz mieć to jak listę, możesz zebrać je wszystkie w zewnętrznym zapytaniu:
SELECT string_agg("Mon-YY", ', ') AS "Mon-YY list"
FROM (
-- Query above
) subsub;