2017-04-19 14 views
0

私はフィルタリングされたナビゲーションをpostgresで実装したいのですが、結果セットから複数のフィールドの各値のカウントを返す方法がわかりません。Postgres:複数の列の集計を取得する方法

例スキーマ:

name: [(Bob, 20), (Joe, 15), (Sue, 5)] 
status[(active, 15), (inactive, 25)] 

答えて

2

チェックGrouping Sets

with t (name, status) as (values 
    ('Bob', 'active'),('Bob', 'active'), 
    ('Joe', 'inactive'),('Joe', 'active'),('Joe', 'active') 
) 
select json_object_agg(case g when 1 then 'name' else 'status' end,a) 
from (
    select jsonb_agg(jsonb_build_object(coalesce(name,status), total)) as a, g 
    from (
     select name, status, count(*) as total, grouping(name,status) as g 
     from t 
     group by grouping sets ((name),(status)) 
    ) s 
    group by g 
) s 
; 
            json_object_agg         
------------------------------------------------------------------------------------ 
{ "name" : [{"Bob": 2}, {"Joe": 3}], "status" : [{"active": 4}, {"inactive": 1}] } 
:私は(この構造を模倣する必要はありません)のようなものを見たいと思い、このクエリの

id, name, status 

+0

ありがとう!これは機能し、グループ分けを理解するのに非常に役立ちました – 2Real

関連する問題