使用PostgreSQL 9.5,有一些jsonbPostgreSQL本身的操作功能(但没有json;需要使用强制转换来操作json)。
合并2个(或更多)JSON对象(或连接数组):SELECT jsonb '{"a":1}' || jsonb '{"b":2}', -- will yield jsonb '{"a":1,"b":2}'
jsonb '["a",1]' || jsonb '["b",2]' -- will yield jsonb '["a",1,"b",2]'
所以,设置一个简单的键可以使用:SELECT jsonb '{"a":1}' || jsonb_build_object('', '')
哪里应该是字符串,而且可以是任何类型的to_jsonb()接受。
为在JSON层次结构中深层设置一个值,jsonb_set()功能可用于:SELECT jsonb_set('{"a":[null,{"b":[]}]}', '{a,1,b,0}', jsonb '{"c":3}')-- will yield jsonb '{"a":[null,{"b":[{"c":3}]}]}'
全参数列表jsonb_set():jsonb_set(target jsonb,
path text[],
new_value jsonb,
create_missing boolean default true)
path也可以包含JSON数组索引&出现在那里的负整数从JSON数组的末尾开始计数。但是,一个不存在但正的JSON数组索引将元素追加到数组的末尾:SELECT jsonb_set('{"a":[null,{"b":[1,2]}]}', '{a,1,b,1000}', jsonb '3', true)-- will yield jsonb '{"a":[null,{"b":[1,2,3]}]}'
为插入JSON数组(同时保留所有原始值),jsonb_insert()函数可以使用(在9.6+中,此函数仅在本节中):SELECT jsonb_insert('{"a":[null,{&#