为什么不能直接在jsonb_array_elements上查询?
Why can't I query directly on jsonb_array_elements?
我在名为 "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
的参数不能 return 一个集合。 jsonb_array_elements
return是一个集合,不能与单个值进行比较。在第二个查询中,您在 select 中有一个交叉连接,并将其转换为合适的结果以在 WHERE
上使用。
你也可以这样做
SELECT mydata.pk FROM mydata
WHERE 'Bob' in (SELECT jsonb_array_elements(mydata.data->'people')->>'name');
此处的 subselect 将允许您使用 IN
运算符来查找所需的值,因为结果不再是集合。
另一种方式是直接查询jsonb
SELECT mydata.pk FROM mydata
WHERE mydata.data->'people' @> '[{"name":"Bob"}]'::jsonb;
这样您就不需要将 jsonb 转换为结果集并在其中进行搜索。
我在名为 "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
的参数不能 return 一个集合。 jsonb_array_elements
return是一个集合,不能与单个值进行比较。在第二个查询中,您在 select 中有一个交叉连接,并将其转换为合适的结果以在 WHERE
上使用。
你也可以这样做
SELECT mydata.pk FROM mydata
WHERE 'Bob' in (SELECT jsonb_array_elements(mydata.data->'people')->>'name');
此处的 subselect 将允许您使用 IN
运算符来查找所需的值,因为结果不再是集合。
另一种方式是直接查询jsonb
SELECT mydata.pk FROM mydata
WHERE mydata.data->'people' @> '[{"name":"Bob"}]'::jsonb;
这样您就不需要将 jsonb 转换为结果集并在其中进行搜索。