首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Postgres plpgsql JSON赋值

Postgres plpgsql JSON赋值
EN

Stack Overflow用户
提问于 2016-02-08 17:38:26
回答 1查看 2.1K关注 0票数 1

我正在Postgres中使用JSONB,并试图了解如何正确地执行对plpgsql中的JSON属性的赋值。

这个查询片段报告了一个语法错误,因为在赋值中使用了前面的括号,但是,我确信这个语法是引用plpgsq中的JSON对象所必需的:

代码语言:javascript
复制
IF (NEW."data")->>'custom' IS NULL THEN
  (NEW."data")->>'custom' := 0;
END IF;

这是在postgresql触发器中,因此NEW是提供给新数据库记录的变量。

有人能建议给JSON(B)属性赋值的正确技术吗?

EN

回答 1

Stack Overflow用户

发布于 2016-02-08 18:07:24

Postgres 9.5中,使用jsonb_set()函数非常简单

代码语言:javascript
复制
if new.data->>'custom' is null then
    new.data = jsonb_set(new.data::jsonb, '{custom}', '0'::jsonb);
end if;

jsonb_set()Postgres 9.4中没有,因此问题更加复杂:

代码语言:javascript
复制
if new.data->>'custom' is null then
    new.data = (
        select json_object_agg(key, value)
        from (
            select key, value
            from jsonb_each(new.data)
            union
            values ('custom', '0'::jsonb)
        ) s
    );
end if;
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35275869

复制
相关文章

相似问题

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