PostgreSQL
 sql >> Base de données >  >> RDS >> PostgreSQL

Mettre à jour la clé imbriquée avec le champ postgres json dans Rails

Il n'y a pas de fonction pour remplacer la clé json, vous devez donc supprimer l'ancien objet et en ajouter un nouveau :

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)