SQL-запрос к условной сумме на основе окна с движущейся датой - PullRequest
18 голосов
/ 12 января 2010

Я пытаюсь выяснить статистику по скользящим окнам для моих пользователей. У меня есть таблица с пользователем, и столбцы, такие как создаются_утвержденным и проверенным_ат. За каждый месяц я хотел бы узнать, сколько пользователей зарегистрировалось (простая группа по 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)

Ответы [ 3 ]

25 голосов
/ 12 января 2010
SELECT  COUNT(created_at) AS registered,
        SUM(CASE WHEN verified_at <= created_at + '60 day'::INTERVAL THEN 1 ELSE 0 END) AS verified
FROM    generate_series(1, 20) s
LEFT JOIN
        users
ON      created_at >= '2009-01-01'::datetime + (s || ' month')::interval
        AND created_at < '2009-01-01'::datetime + (s + 1 || ' month')::interval
GROUP BY
        s
0 голосов
/ 12 января 2010
SELECT
    MONTH,
    COUNT(*) AS Registered,
    SUM (CASE WHEN datediff(day,reg_date,ver_date) < 60 THEN 1 ELSE 0) as 'Verified in 60 //days datediff is an MSSQL function amend for postgresql'
FROM
    TABLE
GROUP BY
    MONTH
0 голосов
/ 12 января 2010

возможно, вы могли бы объединить разные месяцы.

select sum(whatever), 'january' from user where month = 'january'
union all
select sum(whatever), 'february' from user where month = 'february'
...
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...