postgresql json 字段值为数组,怎么查询数组包含指定元素的数据?
json 的格式:{"a":"test","b":[1,2,3,4]}
我想查询所有 b 字段包含了 2 的数据,请问有什么方法可以做到呢?
在 PostgreSQL 中,如果你有一个 JSONB 类型的字段,比如 data
,并且这个字段包含一个数组,你可以使用 @>
操作符来检查 JSONB 数组是否包含特定的元素。对于你的例子,查询可以写成:
SELECT *
FROM your_table
WHERE data -> 'b'::jsonb @> '[2]'::jsonb;
这里,data -> 'b'
会获取 data
字段中的 b
键对应的值,将其转换为 JSONB 类型,然后 @>
检查这个数组是否包含值为 2
的元素。
请注意替换 your_table
为你的实际表名。如果 b
键对应的不是数组,而是字符串或其他非数组类型,查询将会失败,因此确保 b
的值确实是一个 JSONB 数组。
如果你的 JSON 字段是普通的 JSON 类型而不是 JSONB,你需要先将它转换为 JSONB,因为 @>
操作符只适用于 JSONB 类型。转换可以使用 ::jsonb
:
SELECT *
FROM your_table
WHERE (data::jsonb) -> 'b' @> '[2]'::jsonb;
这将确保即使 data
是 JSON 类型,也能正确地进行数组成员检查。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。