小编典典

jsonb内部字段上的Postgres GROUP BY

sql

我正在使用Postgresql 9.4,并具有一个表test,带有id::intcontent::jsonb,如下所示:

 id |     content
----+-----------------
  1 | {"a": {"b": 1}}
  2 | {"a": {"b": 1}}
  3 | {"a": {"b": 2}}
  4 | {"a": {"c": 1}}

如何GROUP BYcontent列的内部字段上将每个组作为数组返回?具体来说,我正在寻找的结果是:

             content
---------------------------------
[{"a": {"b": 1}},{"a": {"b": 1}}]
[{"a": {"b": 2}}]
(2 rows)

试:

SELECT json_agg(content) as content FROM test GROUP BY content ->> '{a,b}';

产量:

                               content
----------------------------------------------------------------------
[{"a": {"b": 1}}, {"a": {"b": 1}}, {"a": {"b": 2}}, {"a": {"c": 1}}]
(1 row)

阅读 295

收藏
2021-03-23

共1个答案

小编典典

您必须使用#>>运算符,而不是->>在正确的操作数是json路径时使用。试试这个:

SELECT json_agg(content) as content FROM test GROUP BY content #>> '{a,b}';

产量:

              content
------------------------------------
 [{"a": {"c": 1}}]
 [{"a": {"b": 2}}]
 [{"a": {"b": 1}}, {"a": {"b": 1}}]
(3 rows)
2021-03-23