Я адаптировал отчет, чтобы создать этот запрос и посмотреть, какие пользователи публиковали сообщения X месяцев назад, и сколько всего пользователей опубликовали сообщения за этот период.
-- [params]
-- int :months_ago = 1
WITH query_period AS (
SELECT
date_trunc('month', CURRENT_DATE) - INTERVAL ':months_ago months' as period_start,
date_trunc('month', CURRENT_DATE) - INTERVAL ':months_ago months' + INTERVAL '1 month' - INTERVAL '1 second' as period_end
)
SELECT
ua.user_id,
count(1) AS post_count
FROM user_actions ua
INNER JOIN query_period qp
ON ua.created_at >= qp.period_start
AND ua.created_at <= qp.period_end
INNER JOIN users u
ON u.id = ua.user_id
AND u.admin = 'f'
AND u.moderator = 'f'
GROUP BY ua.user_id
ORDER BY post_count DESC
Но я не могу получить второе значение — общее количество пользователей, которые публиковали сообщения в этот период. Думаю, мне просто нужен подсчет количества пользователей, включенных в отчет. Буду признателен, если у кого-то есть какие-либо советы.
Редактирование - Забудьте, я вижу, что это можно просто получить из общего количества результатов —
