Я пытаюсь выяснить статистику по скользящим окнам для моих пользователей. У меня есть таблица с пользователем, и столбцы, такие как создаются_утвержденным и проверенным_ат. За каждый месяц я хотел бы узнать, сколько пользователей зарегистрировалось (простая группа по date_trunc для create_at), а затем из этих людей, сколько проверено в моем скользящем окне (назовите это 60 дней).
Я хотел бы сделать SQL-запрос, который дает мне что-то вроде:
Month | Registered | Verified in 60 days
Jan 2009 | 1543 | 107
Feb 2009 | 2000 | 250
Я использую postgresql. Я начинаю смотреть на сумму (case ...), но не знаю, смогу ли я как-нибудь сделать так, чтобы мой случай зависел от date_trunc.
Конечно, это не работает, но вот идея:
SELECT DATE_TRUNC('month', created_at) as month,
COUNT(*) as registered,
SUM(CASE WHEN verified_at < month+60 THEN 1 ELSE 0 END) as verified
FROM users
GROUP BY DATE_TRUNC('month', created_at)