加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

postgresql – 为什么我不能直接在jsonb_array_elements上查询?

发布时间:2020-12-13 18:07:50 所属栏目:百科 来源:网络整理
导读:我将数据存储为名为“data”的列中的jsonb: {'people': [{"name": "Bob","Occupation": "janitor"},{"name": "Susan","Occupation","CEO"}]} 我可以通过以下方式查询: SELECT mydata.pk FROM mydata,jsonb_array_elements(mydata.data-'people') AS a WHER
我将数据存储为名为“data”的列中的jsonb:
{'people': [{"name": "Bob","Occupation": "janitor"},{"name": "Susan","Occupation","CEO"}]}

我可以通过以下方式查询:

SELECT mydata.pk FROM mydata,jsonb_array_elements(mydata.data->'people') AS a WHERE (a->>'name') = 'bob'

为什么我不能用“a”代替jsonb_array_elements(…)?:

SELECT mydata.pk FROM mydata WHERE (jsonb_array_elements(mydata.data->'people')->>'name') = 'bob'

相反,我得到以下内容:

ERROR:  argument of WHERE must not return a set
正如错误消息所示,WHERE的参数不能返回一个集合. jsonb_array_elements返回一个集合,无法与单个值进行比较.在第二个查询中,您在select中有一个交叉连接,并将其转换为合适的结果以使用WHERE.

你也可以这样做

SELECT mydata.pk FROM mydata
  WHERE 'Bob' in (SELECT jsonb_array_elements(mydata.data->'people')->>'name');

此处子选择将允许您使用IN运算符来查找所需的值,因为结果不再是一个集合.

另一种方法是直接查询jsonb

SELECT mydata.pk FROM mydata
  WHERE mydata.data->'people' @> '[{"name":"Bob"}]'::jsonb;

这样您就不需要将jsonb转换为结果集并在其中进行搜索.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读