Rozwiązałem to, wykonując zasadniczo funkcję „unnest()” podobną do jsonb_array_elements()
w mojej zagnieżdżonej tablicy jsonb.
Robiąc to w podzapytaniu, a następnie skanując te wyniki przy użyciu odmiany mojego oryginalnego zapytania, udało mi się osiągnąć pożądany wynik.
Oto, co wymyśliłem.
with dupe as (
select
json_document->>'Name' as name,
identifiers->'RecordID' as record_id
from (
select *,
jsonb_array_elements(json_document->'Identifiers') as identifiers
from staging
) sub
group by record_id, json_document
order by name
)
select * from dupe da where (select count(*) from dupe db where
db.record_id = da.record_id) > 1;