如何解决在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 举报,一经查实,本站将立刻删除。