PostgreSQL
 sql >> Datenbank >  >> RDS >> PostgreSQL

Aktualisieren Sie den verschachtelten Schlüssel mit dem Postgres-json-Feld in Rails

Es gibt keine Funktion zum Ersetzen des json-Schlüssels, daher sollten Sie das alte Objekt löschen und ein neues hinzufügen:

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)