sql >> Base de Datos >  >> RDS >> PostgreSQL

Actualice la clave anidada con el campo json de postgres en Rails

No hay una función para reemplazar la clave json, por lo que debe eliminar el objeto antiguo y agregar uno nuevo:

update moves 
set data = jsonb_set(
    data::jsonb,
    array['boxes'],
    (data->'boxes')::jsonb - 'book' || jsonb_build_object('book_new', data->'boxes'->'book')
    )
where data ->> 'boxes' like '%book%'
returning *;

                         data                         
------------------------------------------------------
 {"boxes": {"moving": 2, "book_new": 2}, "goods": {}}
(1 row)