【问题标题】:Why can't I query directly on jsonb_array_elements?为什么我不能直接在 jsonb_array_elements 上查询?
【发布时间】:2015-08-21 16:02:07
【问题描述】:

我将数据以 jsonb 格式存储在名为“data”的列中:

{'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

【问题讨论】:

    标签: postgresql postgresql-9.4 jsonb


    【解决方案1】:

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

    你也可以这样做

    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 转换为结果集并在其中搜索。

    【讨论】:

    • 当我使用 SELECT mydata.pk FROM mydata WHERE mydata.data->'people' @> '[{"name":"Bob"}]'::jsonb 查询时,我得到的结果包括 Susan 数据集。有没有办法只返回鲍勃的详细信息?
    猜你喜欢
    • 2013-11-14
    • 2014-11-25
    • 2020-04-28
    • 2017-05-27
    • 1970-01-01
    • 2013-02-03
    • 2017-06-26
    • 1970-01-01
    • 2023-03-25
    相关资源
    最近更新 更多