Myślę, że date_trunc
funkcja może być Twoim przyjacielem (zobacz dokumentację postgres ). Chyba zrobiłbyś coś takiego:
select
COUNT(ID) as Total,
COUNT(CASE WHEN createddate between date_trunc('month', now()) AND now() THEN AG.ID END) as ThisMonth,
COUNT(CASE WHEN createddate between date_trunc('month', now()) - interval '1 month' AND date_trunc('month', now()) - interval '1 day' THEN AG.ID END) as LastMonth,
itp...