อัปเดต : ด้วย PostgreSQL 9.5มีjsonbฟังก์ชั่นการจัดการบางอย่างภายใน PostgreSQL เอง (แต่ไม่มีสำหรับjson; casts จำเป็นต้องใช้เพื่อจัดการjsonค่า)
การรวมวัตถุ JSON 2 (หรือมากกว่า) เข้าด้วยกัน (หรือเชื่อมต่ออาร์เรย์):
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('<key>', '<value>')
ไหน<key>ควรเป็นสตริงและ<value>สามารถเป็นสิ่งที่ประเภท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,{"b":[1]}]}', '{a,1,b,0}', jsonb '2')
-- will yield jsonb '{"a":[null,{"b":[2,1]}]}', and
SELECT jsonb_insert('{"a":[null,{"b":[1]}]}', '{a,1,b,0}', jsonb '2', true)
-- will yield jsonb '{"a":[null,{"b":[1,2]}]}'
รายการพารามิเตอร์ทั้งหมดของjsonb_insert():
jsonb_insert(target       jsonb,
             path         text[],
             new_value    jsonb,
             insert_after boolean default false)
อีกครั้งจำนวนเต็มลบที่ปรากฏในการpathนับจากจุดสิ้นสุดของอาร์เรย์ JSON
ดังนั้น f.ex ต่อท้ายอาร์เรย์ JSON สามารถทำได้ด้วย:
SELECT jsonb_insert('{"a":[null,{"b":[1,2]}]}', '{a,1,b,-1}', jsonb '3', true)
-- will yield jsonb '{"a":[null,{"b":[1,2,3]}]}', and
อย่างไรก็ตามฟังก์ชั่นนี้ทำงานแตกต่างกันเล็กน้อย (กว่าjsonb_set()) เมื่อpathin targetคือกุญแจของวัตถุ JSON ในกรณีนั้นมันจะเพิ่มคู่คีย์ - ค่าใหม่สำหรับวัตถุ JSON เมื่อไม่ได้ใช้คีย์ หากมีการใช้งานจะเกิดข้อผิดพลาด:
SELECT jsonb_insert('{"a":[null,{"b":[1]}]}', '{a,1,c}', jsonb '[2]')
-- will yield jsonb '{"a":[null,{"b":[1],"c":[2]}]}', but
SELECT jsonb_insert('{"a":[null,{"b":[1]}]}', '{a,1,b}', jsonb '[2]')
-- will raise SQLSTATE 22023 (invalid_parameter_value): cannot replace existing key
การลบคีย์ (หรือดัชนี)จากวัตถุ JSON (หรือจากอาร์เรย์) สามารถทำได้ด้วยตัว-ดำเนินการ:
SELECT jsonb '{"a":1,"b":2}' - 'a', -- will yield jsonb '{"b":2}'
       jsonb '["a",1,"b",2]' - 1    -- will yield jsonb '["a","b",2]'
การลบจากส่วนลึกของลำดับชั้น JSONสามารถทำได้กับตัว#-ดำเนินการ:
SELECT '{"a":[null,{"b":[3.14]}]}' #- '{a,1,b,0}'
-- will yield jsonb '{"a":[null,{"b":[]}]}'
สำหรับ 9.4คุณสามารถใช้รุ่นที่ปรับเปลี่ยนคำตอบเดิม (ด้านล่าง) แต่แทนที่จะรวมสตริง JSON คุณสามารถรวมเป็นวัตถุ JSON json_object_agg()โดยตรงกับ
คำตอบเดิม : เป็นไปได้ (โดยไม่มี plpython หรือ plv8) ใน pure SQL เช่นกัน (แต่ต้องการ 9.3+ จะไม่ทำงานกับ 9.2)
CREATE OR REPLACE FUNCTION "json_object_set_key"(
  "json"          json,
  "key_to_set"    TEXT,
  "value_to_set"  anyelement
)
  RETURNS json
  LANGUAGE sql
  IMMUTABLE
  STRICT
AS $function$
SELECT concat('{', string_agg(to_json("key") || ':' || "value", ','), '}')::json
  FROM (SELECT *
          FROM json_each("json")
         WHERE "key" <> "key_to_set"
         UNION ALL
        SELECT "key_to_set", to_json("value_to_set")) AS "fields"
$function$;
SQLFiddle
แก้ไข :
เวอร์ชันซึ่งตั้งค่าคีย์และค่าหลายรายการ:
CREATE OR REPLACE FUNCTION "json_object_set_keys"(
  "json"          json,
  "keys_to_set"   TEXT[],
  "values_to_set" anyarray
)
  RETURNS json
  LANGUAGE sql
  IMMUTABLE
  STRICT
AS $function$
SELECT concat('{', string_agg(to_json("key") || ':' || "value", ','), '}')::json
  FROM (SELECT *
          FROM json_each("json")
         WHERE "key" <> ALL ("keys_to_set")
         UNION ALL
        SELECT DISTINCT ON ("keys_to_set"["index"])
               "keys_to_set"["index"],
               CASE
                 WHEN "values_to_set"["index"] IS NULL THEN 'null'::json
                 ELSE to_json("values_to_set"["index"])
               END
          FROM generate_subscripts("keys_to_set", 1) AS "keys"("index")
          JOIN generate_subscripts("values_to_set", 1) AS "values"("index")
         USING ("index")) AS "fields"
$function$;
แก้ไข 2 : เนื่องจาก @ErwinBrandstetter สังเกตว่าฟังก์ชั่นด้านบนใช้งานได้เหมือนที่เรียกUPSERT(อัปเดตฟิลด์หากมีอยู่ให้แทรกหากไม่มีอยู่) นี่คือตัวแปรซึ่งเท่านั้นUPDATE:
CREATE OR REPLACE FUNCTION "json_object_update_key"(
  "json"          json,
  "key_to_set"    TEXT,
  "value_to_set"  anyelement
)
  RETURNS json
  LANGUAGE sql
  IMMUTABLE
  STRICT
AS $function$
SELECT CASE
  WHEN ("json" -> "key_to_set") IS NULL THEN "json"
  ELSE (SELECT concat('{', string_agg(to_json("key") || ':' || "value", ','), '}')
          FROM (SELECT *
                  FROM json_each("json")
                 WHERE "key" <> "key_to_set"
                 UNION ALL
                SELECT "key_to_set", to_json("value_to_set")) AS "fields")::json
END
$function$;
แก้ไข 3 : นี่คือตัวแปรแบบเรียกซ้ำซึ่งสามารถตั้งค่า ( UPSERT) ค่า leaf (และใช้ฟังก์ชันแรกจากคำตอบนี้) ซึ่งอยู่ที่ key-path (ซึ่งคีย์สามารถอ้างถึงวัตถุภายในเท่านั้นไม่สนับสนุนอาร์เรย์ภายใน):
CREATE OR REPLACE FUNCTION "json_object_set_path"(
  "json"          json,
  "key_path"      TEXT[],
  "value_to_set"  anyelement
)
  RETURNS json
  LANGUAGE sql
  IMMUTABLE
  STRICT
AS $function$
SELECT CASE COALESCE(array_length("key_path", 1), 0)
         WHEN 0 THEN to_json("value_to_set")
         WHEN 1 THEN "json_object_set_key"("json", "key_path"[l], "value_to_set")
         ELSE "json_object_set_key"(
           "json",
           "key_path"[l],
           "json_object_set_path"(
             COALESCE(NULLIF(("json" -> "key_path"[l])::text, 'null'), '{}')::json,
             "key_path"[l+1:u],
             "value_to_set"
           )
         )
       END
  FROM array_lower("key_path", 1) l,
       array_upper("key_path", 1) u
$function$;
อัปเดต : ฟังก์ชั่นจะถูกบีบอัดในขณะนี้
               
              
select json_object_set_key((select data from test where data->>'b' = '2'), 'b', 'two');ข้อความแสดงข้อผิดพลาดคือERROR: could not determine polymorphic type because input has type "unknown"