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

6 postgresql jsonb postgresql-9.4

我将数据存储为名为"data"的列中的jsonb:

{'people': [{"name": "Bob", "Occupation": "janitor"}, {"name": "Susan", "Occupation", "CEO"}]}
Run Code Online (Sandbox Code Playgroud)

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

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

为什么我不能用"a"代替jsonb_array_elements(...)?:

SELECT mydata.pk FROM mydata WHERE (jsonb_array_elements(mydata.data->'people')->>'name') = 'bob' 
Run Code Online (Sandbox Code Playgroud)

相反,我得到以下内容:

ERROR:  argument of WHERE must not return a set
Run Code Online (Sandbox Code Playgroud)

Sam*_*nen 11

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

你也可以这样做

SELECT mydata.pk FROM mydata
  WHERE 'Bob' in (SELECT jsonb_array_elements(mydata.data->'people')->>'name');
Run Code Online (Sandbox Code Playgroud)

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

另一种方法是直接查询jsonb

SELECT mydata.pk FROM mydata
  WHERE mydata.data->'people' @> '[{"name":"Bob"}]'::jsonb;
Run Code Online (Sandbox Code Playgroud)

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