微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

在Postgres 12中更新整个JSONB对象

如何解决在Postgres 12中更新整个JSONB对象

我很难用新的JSONB对象替换名为config的列中的JSONB对象。

根据Postgres(12)文档,应该使用jsonb_set来更新现有的JSON记录:我正在尝试使用以下指令替换现有的JSONB:

UPDATE table SET config=jsonb_set(config,'{config}','{"newKey":"newValue"}') WHERE myUpdateCondition;

问题在于,这对{"newKey":"newValue"}已成功添加config中,但先前的JSONB仍然存在于config列中:我的目标是完全 更新config{"newKey":"newValue"},仅保留了先前的JSONB。

我正在阅读有关jsonb_delete的信息,但是我没有在官方文档中找到它。

如何通过不保留以前的JSONB对象并将其完全替换为新的JSONB对象的方式来更新JSONB config列?

解决方法

我的目标是仅使用{“ newKey”:“ newValue”}来完全更新配置,而不再保留以前的JSONB。

然后只需分配新值:

UPDATE table 
  SET config= '{"newKey":"newValue"}'
WHERE ...;

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。