postgresql - 在 postgres SQL 中查询 jsonb 字段
问题描述
我正在尝试从 jsonb 列中获取最大日期。
我收到以下错误..
------------------------------------
id | obj_value(jsonb)
------------------------------------
1 | {"value": [{"date": "2020-12-2020"}]}
------------------------------------
2 | {"value": [{"date": "2020-12-2019"}]}
---------------------------------
3 | {"value": [{"date": "2020-12-2018"}]}
---------------------------------
这是 SQL 查询
SELECT max(obj_value->'value'->0->'effectiveDate')
FROM public.tbl_data
where obj_value->'value'->0->>'effectiveDate' <= TO_CHAR(CURRENT_DATE, 'YYYY-MM-DD')
我收到以下错误..
ERROR: function max(jsonb) does not exist
LINE 1: SELECT max(obj_value->'value'->0->'effectiveDate')
^
HINT: No function matches the given name and argument types. You might need to add explicit type casts.
SQL state: 42883
Character: 8
解决方案
->
运算符返回JSONB
类型,
->>
返回TEXT
类型。
您应该使用->>
然后转换为您需要的类型
推荐阅读
- kotlin - 表示可以是两个原语的值的惯用方式?
- ruby-on-rails - on_file_autoloaded':预期文件invitations_controller.rb 定义常量InvitationsController,但没有(Zeitwerk::NameError)
- sql-server - x 与 x 无关!续集打字稿中的错误
- python - 如何检查 docker 镜像是否从 python 脚本成功推送
- google-analytics - dataLayer 的变量不会传递给 Google.Analytics。| Google Analytics 中的事件操作显示“未定义”
- javascript - 动态反应形式的自定义验证器不起作用
- azure - Azure-AKS:使用 Postman 测试启用 TLS 的 Ingress
- javascript - 无法在反应钩子中调整 d3 v6 的大小?
- javascript - 如何从 vue.js 中的多个路径导入使用相同名称的组件或实用程序?
- c - 这段代码是什么意思?#define PARAM_ARGS \ struct a