我将数据作为 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