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

标签 postgresql postgresql-9.4 jsonb

我将数据作为 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 运算符来查找所需的值,因为结果不再是一个集合。

另一种方式是直接查询jsonb

SELECT mydata.pk FROM mydata
  WHERE mydata.data->'people' @> '[{"name":"Bob"}]'::jsonb;

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

关于postgresql - 为什么不能直接在jsonb_array_elements上查询?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30687945/

相关文章:

sql - 时间戳格式 - 从 1/1000 秒到 1/100 秒

postgresql - 如何在 Postgres 9.4 中对 JSONB 类型的列执行更新操作

Postgresql 9.4 级联复制故障转移

json数据存入postgresql顺序不同

postgresql - "("postgresql + Python 处或附近的语法错误

sql - 使用递归 sql 计算平均成本(postgres 9.1)

ruby-on-rails - 安装 do_postgres (0.10.16) 时发生错误 Bundler 无法继续。确保 'gem install do_postgress -v ' 0.10.16' 成功

mysql - 需要为表中存在的每一行获取 true/false

arrays - PostgreSQL 中 json 数组值的交集

sql - Postgres 9.4 jsonb 数组作为表