PostgreSQL json 用于查找具有特定键的第一个数组元素的路径表达式
PostgreSQL json path expression to find first array element having a specific key
我需要一个 jsonpath 表达式,它 returns 具有“键”的数组的第一个元素 属性。
我正在寻找与此查询相同的结果:
SELECT
j
FROM
jsonb_array_elements(
'[
{"key": "foo"},
{"other": "bar"},
{"key": "baz", "other": "blah"}
]'::JSONB
) j
WHERE
j ? 'key'
LIMIT 1
我的查询目前看起来像这样,但不起作用
SELECT
jsonb_path_query(
'[
{"key": "foo"},
{"other": "bar"},
{"key": "baz", "other": "blah"}
]'::JSONB,
'$[?(@.key)] [0]')
请看这个:https://www.postgresql.org/docs/12/functions-json.html#FUNCTIONS-SQLJSON-PATH-OPERATORS
SELECT
jsonb_path_query_first(
'[
{"key": "foo"},
{"other": "bar"},
{"key": "baz", "other": "blah"}
]'::JSONB,
'$[*] ? (exists (@.key))')
;
jsonb_path_query_first
------------------------
{"key": "foo"}
(1 row)
我需要一个 jsonpath 表达式,它 returns 具有“键”的数组的第一个元素 属性。
我正在寻找与此查询相同的结果:
SELECT
j
FROM
jsonb_array_elements(
'[
{"key": "foo"},
{"other": "bar"},
{"key": "baz", "other": "blah"}
]'::JSONB
) j
WHERE
j ? 'key'
LIMIT 1
我的查询目前看起来像这样,但不起作用
SELECT
jsonb_path_query(
'[
{"key": "foo"},
{"other": "bar"},
{"key": "baz", "other": "blah"}
]'::JSONB,
'$[?(@.key)] [0]')
请看这个:https://www.postgresql.org/docs/12/functions-json.html#FUNCTIONS-SQLJSON-PATH-OPERATORS
SELECT
jsonb_path_query_first(
'[
{"key": "foo"},
{"other": "bar"},
{"key": "baz", "other": "blah"}
]'::JSONB,
'$[*] ? (exists (@.key))')
;
jsonb_path_query_first
------------------------
{"key": "foo"}
(1 row)