Top 50 mi piace

I 50 principali utenti che hanno messo “Mi piace”

Restituisce i 50 utenti che hanno messo più “Mi piace” per un determinato periodo mensile. I risultati sono ordinati in base a like_count. Accetta un parametro ‘months_ago’ e, per impostazione predefinita, assume il valore 0 per restituire i risultati relativi al mese corrente.

-- [parametri]
-- 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 like_count
FROM user_actions ua
INNER JOIN query_period qp
ON ua.created_at >= qp.period_start
AND ua.created_at <= qp.period_end
WHERE ua.action_type = 1
GROUP BY ua.user_id
ORDER BY like_count DESC
LIMIT 50