• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    postgresql的jsonb数据查询和修改的方法

    什么是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 数据库跨版本升级常用方案解析
    下一篇:如何将excel表格数据导入postgresql数据库
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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