使用 Postgres 中的嵌套数组高效查询 JSON

杰弗里·加拉韦

我正在尝试在 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] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章