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

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

概述我将数据存储为名为“data”的列中的jsonb: {'people': [{"name": "Bob", "Occupation": "janitor"}, {"name": "Susan", "Occupation", "CEO"}]} 我可以通过以下方式查询: SELECT mydata.pk FROM mydata, jsonb_array_elements(mydata.data->'p 我将数据存储为名为“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转换为结果集并在其中进行搜索.

总结

以上是内存溢出为你收集整理的postgresql – 为什么我不能直接在jsonb_array_elements上查询?全部内容,希望文章能够帮你解决postgresql – 为什么我不能直接在jsonb_array_elements上查询?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1181623.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存