我正在尝试在 Postgres(Amazon RDS 上的 9.6)中查询 JSON 数据结构。数据包含一个对象数组,而对象数组又包含一个包含对象数组的元素。我想在这些嵌套数组之一中找到与键 + 值匹配的所有记录。
给定这样的行:
{"drinkers" : [
{"name" : "geoff",
"beers" : [
{"name": "PBR"},
{"name" : "Bud Select"}
]},
{"name" : "tom",
"beers" : [
{"name": "Bud Light"},
{"name" : "Busch"}
]}
]}
我想找到名称为“PBR”的drinkers.beers 对象的所有行。我最接近的是这个:
select jsonb_data
from bars
where jsonb_array_elements(jsonb_array_elements(data -> 'drinkers') -> 'beers') ->> 'name' = 'PBR'``
但这不起作用,因为 where 返回一个列表而不是单个真/假来匹配。我已经使用子查询、横向连接等提出了其他解决方案,但所有这些解决方案都存在性能问题,即使使用适当的 gin 索引也是如此。关于如何在 Postgres 中查询这样的数据结构有什么建议吗?
您是否尝试使用IN
运算符?
WHERE 'PBR' IN (
SELECT jsonb_array_elements(jsonb_array_elements(data -> 'drinkers') -> 'beers') ->> 'name'
);
另一种方法是使用 JSONB contain
(即@>
):
WHERE data -> 'drinkers' @> '[{"beers": [{"name": "PBR"}]}]';
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句