主页 > 知识库 > postgresql的jsonb数据查询和修改的方法

postgresql的jsonb数据查询和修改的方法

热门标签:电话机器人录音师薪资 高德地图标注电话怎么没了 无锡梁溪公司怎样申请400电话 奥维地图标注字体大小修改 江西稳定外呼系统供应商 北京智能外呼系统供应商家 中国地图标注省份用什么符号 孝感销售电销机器人厂家 智能电销机器人教育

什么是jsonb
由PostgreSQL文档定义的数据类型json和jsonb几乎相同;关键的区别在于json数据存储为JSON输入文本的精确副本,而jsonb以分解的二进制形式存储数据;也就是说,不是ASCII / UTF-8字符串,而是二进制代码。

本文主要讲的是如何随心所欲的查询和修改postgresql中jsonb格式的数据

一、查询

简单查询

# 存储的是key-value格式的数据,通过指定的key获取对应的值
# 使用->返回的结果是带引号的
select '{"nickname": "goodspeed", "avatar": "avatar_url"}'::json->'nickname' as nickname;
# 使用->>返回结果不带引号
select '{"nickname": "goodspeed", "avatar": "avatar_url", "tags": ["python", "golang", "db"]}'::json->>'nickname' as nickname;

复杂查询

# {tags,0}代表查询key=‘tags',且value为数组中数组的第一个元素
select '{"nickname": "gs", "avatar": "avatar_url", "tags": ["python", "golang", "db"]}'::json#>'{tags,0}' as tag;
# {aa,b,0}代表查询key=‘aa',对应的value中,key=‘b'的value中,数组的第一个元素
select '{"nickname": "gs", "avatar": "avatar_url", "tags": ["python", "golang", "db"], "aa":{"b": [{"c": 1}]}}'::jsonb#>>'{aa,b,0}';

二、修改

修改

jsonb_set(原数据, 需要更改的位置, 替换的值,是否不存在时新增), 
select jsonb_set('[{"f1":1,"f2":null},2,null,3]', '{0,f1}','[2,3,4]', false);

到此这篇关于postgresql的jsonb数据查询和修改的文章就介绍到这了,更多相关postgresql jsonb数据查询和修改内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
  • postgresql 实现修改jsonb字段中的某一个值
  • PostgreSQL 更新JSON,JSONB字段的操作
  • 介绍PostgreSQL中的jsonb数据类型
  • 关于PostgreSQL JSONB的匹配和交集问题

标签:阜阳 荆州 通化 临沧 海北 泰州 那曲 齐齐哈尔

巨人网络通讯声明:本文标题《postgresql的jsonb数据查询和修改的方法》,本文关键词  postgresql,的,jsonb,数据查询,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《postgresql的jsonb数据查询和修改的方法》相关的同类信息!
  • 本页收集关于postgresql的jsonb数据查询和修改的方法的相关信息资讯供网民参考!
  • 企业400电话

    智能AI客服机器人
    15000

    在线订购

    合计11份范本:公司章程+合伙协议+出资协议+合作协议+股权转让协议+增资扩股协议+股权激励+股东会决议+董事会决议

    推荐文章