pg数据库json数据类型_如何修改新PostgreSQLJSON数据类型中的字段?

本文介绍了在PostgreSQL 9.5中如何使用jsonb类型操作JSON数据,包括合并JSON对象、设置和更新JSON层次结构中的值,以及删除键。提到了jsonb_set()和jsonb_insert()等函数的用法,以及针对9.4及更低版本的解决方案。
摘要由CSDN通过智能技术生成

使用PostgreSQL 9.5,有一些jsonbPostgreSQL本身的操作功能(但没有json;需要使用强制转换来操作json)。

合并2个(或更多)JSON对象(或连接数组):SELECT jsonb '{"a":1}' || jsonb '{"b":2}', -- will yield jsonb '{"a":1,"b":2}'

jsonb '["a",1]' || jsonb '["b",2]'  -- will yield jsonb '["a",1,"b",2]'

所以,设置一个简单的键可以使用:SELECT jsonb '{"a":1}' || jsonb_build_object('', '')

哪里应该是字符串,而且可以是任何类型的to_jsonb()接受。

为在JSON层次结构中深层设置一个值,jsonb_set()功能可用于:SELECT jsonb_set('{"a":[null,{"b":[]}]}', '{a,1,b,0}', jsonb '{"c":3}')-- will yield jsonb '{"a":[null,{"b":[{"c":3}]}]}'

全参数列表jsonb_set():jsonb_set(target         jsonb,

path           text[],

new_value      jsonb,

create_missing boolean default true)

path也可以包含JSON数组索引&出现在那里的负整数从JSON数组的末尾开始计数。但是,一个不存在但正的JSON数组索引将元素追加到数组的末尾:SELECT jsonb_set('{"a":[null,{"b":[1,2]}]}', '{a,1,b,1000}', jsonb '3', true)-- will yield jsonb '{"a":[null,{"b":[1,2,3]}]}'

为插入JSON数组(同时保留所有原始值),jsonb_insert()函数可以使用(在9.6+中,此函数仅在本节中):SELECT jsonb_insert('{"a":[null,{&#

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值