导读:本期聚焦于小伙伴创作的《如何在PostgreSQL中更新JSONB字段的特定属性_使用jsonb_set函数》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《如何在PostgreSQL中更新JSONB字段的特定属性_使用jsonb_set函数》有用,将其分享出去将是对创作者最好的鼓励。

PostgreSQL作为主流的关系型数据库,原生支持JSONB类型存储半结构化数据,实际业务中经常需要修改JSONB字段里的特定属性,而不是替换整个字段内容,jsonb_set函数就是完成这类操作的核心工具。

如何在PostgreSQL中更新JSONB字段的特定属性_使用jsonb_set函数

jsonb_set函数基本语法

jsonb_set函数的标准语法格式如下:

jsonb_set(target jsonb, path text[], new_value jsonb [, create_missing boolean])

各个参数的含义分别是:

  • target:需要被修改的原始JSONB字段或者JSONB值
  • path:指定要修改的属性的路径,是一个文本数组,数组元素对应JSON的层级键名,如果是数组索引则使用数字字符串
  • new_value:要设置的新属性值,必须是JSONB类型
  • create_missing:可选参数,默认值为true,表示如果路径不存在是否创建该属性,设置为false时路径不存在则不执行修改

基础更新场景示例

更新普通单层属性

假设我们有一张用户表,其中extra_info字段是JSONB类型,存储用户的额外信息,现在需要把id为1的用户的年龄属性更新为25。

首先创建测试表和测试数据:

-- 创建用户表
CREATE TABLE user_info (
    id INT PRIMARY KEY,
    extra_info JSONB
);
-- 插入测试数据
INSERT INTO user_info (id, extra_info) VALUES 
(1, '{"name": "张三", "age": 20, "hobby": "篮球"}'),
(2, '{"name": "李四", "age": 22, "hobby": "足球"}');

执行更新操作的SQL语句如下:

UPDATE user_info 
SET extra_info = jsonb_set(extra_info, '{age}', '25')
WHERE id = 1;

更新后查询id为1的用户数据,extra_info字段会变成{"name": "张三", "age": 25, "hobby": "篮球"},年龄属性已经成功修改。

更新嵌套属性

如果JSONB字段存在嵌套结构,比如extra_info里包含address对象,需要修改address里的city属性,路径数组需要逐层指定键名。

先插入一条带嵌套结构的数据:

INSERT INTO user_info (id, extra_info) VALUES 
(3, '{"name": "王五", "age": 28, "address": {"city": "北京", "street": "朝阳路"}}');

更新city为上海的SQL语句:

UPDATE user_info 
SET extra_info = jsonb_set(extra_info, '{address,city}', '"上海"')
WHERE id = 3;

这里路径数组是{address,city},对应JSON里的address对象下的city属性,新值需要用双引号包裹表示字符串类型的JSONB值。

特殊场景更新示例

更新JSONB数组内的元素

如果JSONB字段里包含数组,需要修改数组指定索引的元素,路径数组里使用数字字符串表示数组索引,注意PostgreSQL的JSONB数组索引是从0开始的。

插入包含数组的数据:

INSERT INTO user_info (id, extra_info) VALUES 
(4, '{"name": "赵六", "scores": [80, 90, 85]}');

把scores数组的第一个元素(索引0)更新为95:

UPDATE user_info 
SET extra_info = jsonb_set(extra_info, '{scores,0}', '95')
WHERE id = 4;

更新后scores数组会变成[95, 90, 85]

路径不存在时的处理

默认情况下create_missing参数为true,如果指定的路径不存在,会自动创建该属性。如果不需要创建,可以显式设置为false。

比如尝试更新id为1的用户不存在的gender属性,设置create_missing为false:

UPDATE user_info 
SET extra_info = jsonb_set(extra_info, '{gender}', '"男"', false)
WHERE id = 1;

执行后该用户的extra_info不会新增gender属性,因为路径不存在且不允许创建。

使用注意事项

  • 新值参数必须是JSONB类型,如果是普通字符串需要包裹成JSON字符串,比如字符串值要写成'"字符串内容"',数字直接写数字字符串即可
  • 路径数组的元素如果是键名直接写字符串,如果是数组索引写对应的数字字符串,多个层级用逗号分隔
  • 如果要更新的属性值本身是JSONB对象或者数组,新值可以直接写对应的JSON结构,比如'{"key": "value"}'或者'[1,2,3]'
  • 批量更新时jsonb_set函数会逐行处理,大表更新时注意评估性能影响,必要时可以添加合适的索引提升查询效率
jsonb_set函数只修改指定路径的属性,不会影响JSONB里的其他属性,相比整体替换JSONB字段的方式,能减少不必要的数据写入,提升操作效率。

PostgreSQLJSONBjsonb_set数据库更新修改时间:2026-07-01 23:42:30

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。