Postgres plpgsql JSON 赋值

Posted

技术标签:

【中文标题】Postgres plpgsql JSON 赋值【英文标题】:Postgres plpgsql JSON assignment 【发布时间】:2016-02-08 17:38:26 【问题描述】:

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

这个查询 sn-p 报告了一个语法错误,因为赋值的前括号,但是我很确定这个语法是引用 plpgsq 中的 JSON 对象所必需的:

IF (NEW."data")->>'custom' IS NULL THEN
  (NEW."data")->>'custom' := 0;
END IF;

这是在 postgresql 触发器中,所以 NEW 是提供的与新数据库记录相关的变量。

有人可以建议将值分配给 JSON(B) 属性的正确技术是什么吗?

【问题讨论】:

9.4...很快就会是 9.5。 【参考方案1】:

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

if new.data->>'custom' is null then
    new.data = jsonb_set(new.data::jsonb, 'custom', '0'::jsonb);
end if;

Postgres 9.4 中没有jsonb_set(),所以问题更复杂:

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;

【讨论】:

以上是关于Postgres plpgsql JSON 赋值的主要内容,如果未能解决你的问题,请参考以下文章

如何在 Postgres/plpgsql 的视图定义中使用变量

无法执行 plpgsql/postgres 中的函数

将数组从 node-postgres 传递给 plpgsql 函数

避免在 postgres plpgsql 函数中几乎重复查询

创建语法处或附近的 Plpgsql 函数错误

如何在不创建函数的情况下运行 plpgsql?