微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Postgres jsonb_path_query 按长度过滤子数组

如何解决Postgres jsonb_path_query 按长度过滤子数组

在 Postgres 13.3 中,我想从 jsonb 值中提取特定长度的子数组:

select jsonb_path_query('[[0,1],[0,1,2]]'::jsonb,'$[*] ? (@.size() >= 3)');

但是,这不返回任何内容(0 行)。

我做错了什么? 请注意,我想继续使用 jsonpath - 虽然此示例已简化,但实际情况要复杂得多,并且依赖于 jsonpath 表达式的灵活性。

解决方法

$[*] 将在当时执行数组中的每个元素,因此分别计算 0,1,0,{{ 1}}

以下是诀窍

2

结果

select jsonb_path_query('[[0,1],[0,1,2]]'::jsonb,'$ ? (@.size() >= 3)');

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。