繁体   English   中英

JSONB 查询数组

[英]JSONB Querying array

我在 PostgreSQL 表中有以下列,该表有一个 JSONB 字段,其数据如下:

[{"id":33,"url":"","name":"test"}, {"id":45,"url":"","name":"test"}]

我正在尝试查询它并返回与 id 匹配的元素。 我在 Rails 中有以下查询,但似乎不匹配:

Book.where('data @>?', '[{"id": 33}]')

由于您只需要 jsonb 数组中的一些元素,因此您需要将它们转换为记录并将它们与它们的父元素交叉连接:

Book.joins(", jsonb_array_elements(books.data) obj")
    .where("obj->>'id' = '33'")
    .select("obj")

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM