关于 pgsql 中 jsonb 类型数据的更新问题 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
jiobanma
V2EX    Java

关于 pgsql 中 jsonb 类型数据的更新问题

  •  
  •   jiobanma
    banmajio Sep 29, 2020 1466 views
    This topic created in 2047 days ago, the information mentioned may be changed or developed.

    如一张 pgsql 的表里面有个字段 data 的属性为 jsonb,在进行更新操作时如何对传入的 json 字符串进行解析,对应源数据如果有相同的 key 就替换 value,如果没有,就新增一个 key-value 进去。 比如源数据为{"A":"a","B":"b","C":"c"} 执行更新时我传入的参数为:{"A":"00","D":"d"} 希望的到的数据是:{"A":"a","B":"b","C":"c"}
    查了查 jsonb_set 这个函数,感觉这个只能指定某个 key 和 value 来进行更新,而不能只能识别我传入的一个 json 去进行相应的操作。

    还有其他什么好的办法吗

    3 replies    2020-09-30 09:10:58 +08:00
    crclz
        1
    crclz  
       Sep 29, 2020
    最简单、最不容易出 bug 的解决方案是:整存整取。
    唯一的问题是性能问题。所以,一个 jsonb 字段既不能过大从而影响性能,也不能过小从而让一个业务操作设计太多实体。
    pabupa
        2
    pabupa  
       Sep 30, 2020
    可以用操作符。

    `select '{"A":1,"B":2}'::jsonb || '{"A":3, "D": 4}';`
    jiobanma
        3
    jiobanma  
    OP
       Sep 30, 2020
    @crclz #1 是的 整存整取确实就没这个问题了,但是我们现在数据库设计的比较... 查询出来的数据是视图里处理好的数据 更新时要往基础表更新 有很多字段对应不上,前端那边是不知道字段的对应关系的,所以有些业务整存整取无法实现。
    @pabupa #2 现在用的就是这个 被百度误导了 以为这个操作符只是在之前的数据后边拼接 不会覆盖的
    About     Help     Advertse     Blog     API     FAQ     Solana     4505 Online   Highest 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 29ms UTC 00:09 PVG 08:09 LAX 17:09 JFK 20:09
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86