18

ユーザーのスライディングウィンドウ統計を把握しようとしています。ユーザーとcreated_atやverified_atなどの列を持つテーブルがあります。毎月、登録したユーザーの数(created_atのdate_truncによる単純なグループ)を調べ、次にそれらのユーザーの数をスライディングウィンドウ内で確認した数(60日と呼びます)を調べたいと思います。

次のようなSQLクエリを実行したいと思います。

Month    | Registered | Verified in 60 days
Jan 2009 | 1543       | 107
Feb 2009 | 2000       | 250

私はpostgresqlを使用しています。私はsum(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)
4

3 に答える 3

25
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
于 2010-01-11T22:45:57.923 に答える
0

おそらく、あなたは異なる月を一緒に結合することができます。

select sum(whatever), 'january' from user where month = 'january'
union all
select sum(whatever), 'february' from user where month = 'february'
...
于 2010-01-11T22:39:49.773 に答える
0
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
于 2010-01-11T22:47:48.883 に答える