通过可变路径访问 JSONB 元素
Accessing JSONB element by a variable path
我需要将两个 json 值合并为一个。
但是这些变量的位置是动态的,我从数据库中获取 jsonb 中的位置。
所以我希望能够做这样的事情:
select '{"a": {"b": {"c": "d"}}}'::jsonb #> '{"a","b","c"}';
但我无法让它与变量一起工作,因为我不知道将路径投射到什么。
select '{"a": {"b": {"c": "d"}}}'::jsonb #> ('{"a","' || variable_from_database || '","c"}')::dataTypeOfJsonbPath;
我还发现我可以使用这样的查询:
select value#>>'{"c"}' from jsonb_each(('{"a": {"b": {"c": "d"}}}'::jsonb#>'{"a"}')) where key = 'b';
这将解决获取值的问题,但现在我需要将它们连接到原始 jsonb 值中,而我目前不知道如何完成该操作。
jsonb_set('{"a": {"b": {"c": "d"}}}'::jsonb, ('{"a","' || value2FromDatabase || '", "c"}'),
(value1 || value2)::jsonb, false);
以上同样的原因失败了。
列出 jsonb_set 所需的参数告诉我第二个参数应该是 ARRAY 类型,但我不知道如何将该字符串转换为数组才能使它正常工作。
任何人都可以指出如何在 jsonb 对象中将一个值附加到另一个值的正确方向,其中两者的键都位于动态位置?
select '{"a": {"b": {"c": "d"}}}'::jsonb #>> ('{"a","'||'b'||'","c"}')::text[];
行得通,所以我需要转换为文本[]。
行得通!
将您的路径转换为类型 text[]
SELECT
'{"a": {"b": {"c": "d"}}}'::jsonb #> ('{"a","' || path || '","c"}')::text[]
FROM
mytable
我需要将两个 json 值合并为一个。 但是这些变量的位置是动态的,我从数据库中获取 jsonb 中的位置。
所以我希望能够做这样的事情:
select '{"a": {"b": {"c": "d"}}}'::jsonb #> '{"a","b","c"}';
但我无法让它与变量一起工作,因为我不知道将路径投射到什么。
select '{"a": {"b": {"c": "d"}}}'::jsonb #> ('{"a","' || variable_from_database || '","c"}')::dataTypeOfJsonbPath;
我还发现我可以使用这样的查询:
select value#>>'{"c"}' from jsonb_each(('{"a": {"b": {"c": "d"}}}'::jsonb#>'{"a"}')) where key = 'b';
这将解决获取值的问题,但现在我需要将它们连接到原始 jsonb 值中,而我目前不知道如何完成该操作。
jsonb_set('{"a": {"b": {"c": "d"}}}'::jsonb, ('{"a","' || value2FromDatabase || '", "c"}'),
(value1 || value2)::jsonb, false);
以上同样的原因失败了。
列出 jsonb_set 所需的参数告诉我第二个参数应该是 ARRAY 类型,但我不知道如何将该字符串转换为数组才能使它正常工作。
任何人都可以指出如何在 jsonb 对象中将一个值附加到另一个值的正确方向,其中两者的键都位于动态位置?
select '{"a": {"b": {"c": "d"}}}'::jsonb #>> ('{"a","'||'b'||'","c"}')::text[];
行得通,所以我需要转换为文本[]。 行得通!
将您的路径转换为类型 text[]
SELECT
'{"a": {"b": {"c": "d"}}}'::jsonb #> ('{"a","' || path || '","c"}')::text[]
FROM
mytable