Postgres/JSON - update all array elements

后端 未结 2 1451
佛祖请我去吃肉
佛祖请我去吃肉 2021-01-20 15:25

Given the following json:

{
  \"foo\": [
    {
      \"bar\": true
    },
    {
      \"bar\": true
    }
  ]
}

How can I select the follow

2条回答
  •  离开以前
    2021-01-20 16:03

    You might want to kill two birds with one stone - update existing key in every object in the array or insert the key with a given value. jsonb_set is a perfect match here, but it requires us to pass the index of each object, so we have to iterate over the array first.

    The implementation is HIGHLY inspired by klin's answer, which didn't solve my problem (which was updating and inserting) and didn't work if there were multiple keys in the object. So, the implementation is as follows:

    -- the params are the same as in aforementioned `jsonb_set`
    CREATE OR REPLACE FUNCTION update_array_elements(target jsonb, path text[], new_value jsonb)
      RETURNS jsonb language sql AS $$
        -- aggregate the jsonb from parts created in LATERAL
        SELECT jsonb_agg(updated_jsonb)
        -- split the target array to individual objects...
        FROM jsonb_array_elements(target) individual_object,
        -- operate on each object and apply jsonb_set to it. The results are aggregated in SELECT
        LATERAL jsonb_set(individual_object, path, new_value) updated_jsonb
      $$;
    

    And that's it... :)

    I hope it'll help someone with the same problem I had.

提交回复
热议问题