首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >更新jsonb列

更新jsonb列
EN

Stack Overflow用户
提问于 2017-03-29 21:47:28
回答 1查看 260关注 0票数 2

我试图以此处指定的形式更新Postrgres db中列中的用户事实。

jsonb目前在数据列中等待更新:

data = { "type1" : ["value1", "value2"], "type2" : ["value3"], "type3" : ["value4"] }

发送到db的jsonb:

new_jsonb = { "type1" : ["value7", "value8"], "type3" : ["value6"]}

jsonb应该如何处理它的更新:

updated_jsonb = { "type1: ["value7", "value8"], "type2": ["value3"], "type3": ["value6"] }

将原始数据集中的值与我们想要更新的值进行比较时的基本规则如下:

  1. 如果正在传递的new_jsonb包含不在当前data jsonb中的键,那么这些键将被添加到它们的值中。
  2. 如果正在传递的new_jsonb包含当前data jsonb中的键,那么这些密钥都只是替换旧的键。

post做了一项有用的工作,概述了jsonb_set函数的一般用途,但我在数组中进行比较时遇到了困难。特别指定path参数。

所以,基本上,我被困的地方是不知道该指定什么路径来实现这一点。我拥有的是UPDATE table_name SET data = jsonb_set(data {don't know what path should be}, new) WHERE customer_id = $customerId。被传递的new_jsonb并不总是按照相同的顺序传递键值对。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-03-29 22:20:15

使用级联操作符:

代码语言:javascript
复制
UPDATE table_name 
SET data = data || $newData
WHERE customer_id = $customerId;

示例:

代码语言:javascript
复制
SELECT 
    '{ "type1": ["value1", "value2"], "type2": ["value3"], "type3": ["value4"] }'::jsonb ||
    '{ "type1": ["value7", "value8"], "type3": ["value6"]}'::jsonb as result

                                  result                                   
---------------------------------------------------------------------------
 {"type1": ["value7", "value8"], "type2": ["value3"], "type3": ["value6"]}
(1 row)
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43104744

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档