[英]Query jsonb fields in the postgres SQL
我正在嘗試從 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
類型。
您應該使用->>
然后轉換為您需要的類型
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.