我将数据存储为名为“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运算符来查找所需的值,因为结果不再是一个集合.
SELECT mydata.pk FROM mydata WHERE mydata.data->'people' @> '[{"name":"Bob"}]'::jsonb;
这样您就不需要将jsonb转换为结果集并在其中进行搜索.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。