Преобразование JSONB в обычный массив в Postgres - PullRequest
0 голосов
/ 26 ноября 2018

У меня есть следующая таблица:

"Id"|                  "Data"
====+================================================
1   | { "emp": [ 
    |            {"id": "a1", "otherdata": "other"}, 
    |            {"id": "a2", "otherdata": "other"} 
    |          ]
    | }
----+------------------------------------------------
2   | { "emp": [ 
    |            {"id": "b1", "otherdata": "other"}, 
    |            {"id": "b2", "otherdata": "other"} 
    |          ]
    | }
-----------------------------------------------------

Где "Данные" - это jsonb.

Мне нужно создать временную таблицу этого типа:

"Id"| "Emp"
====+=============
1   | {"a1", "a2"}
----+-------------
2   | {"b1", "b2"}

Как я могу это сделать?

1 Ответ

0 голосов
/ 26 ноября 2018

Используйте jsonb_to_recordset, чтобы извлечь значения массива в строки, сгруппировать их, а затем обратно в массив, используя array_to_json.

SELECT a.id, array_to_json(array_agg(b.id)) AS emp
FROM mytable a
CROSS JOIN jsonb_to_recordset(a.data->'emp') AS b(id text)
GROUP BY a.id;

См. SQL Fiddle

...