yuan-er

导航

 

JSONB高级特性

  • 注意事项
    • 不支持作为分区键。
    • 不支持外表。

​JSON和JSONB的主要差异在于存储方式上的不同,JSONB存储的是解析后的二进制,能够体现JSON的层次结构,更方便直接访问等,因此JSONB会有很多JSON所不具有的高级特性。

  • 格式归一化
    • 对于输入的object-json字符串,解析成jsonb二进制后,会天然的丢弃语义上无关紧要的细节,比如空格:
      gaussdb=# SELECT '   [1, " a ", {"a"   :1    }]  '::jsonb;
              jsonb
      ----------------------
       [1, " a ", {"a": 1}]
      (1 row)
       
       
    • 对于object-json,会删除重复的键值,只保留最后一个出现的,如:
      gaussdb=# SELECT '{"a" : 1, "a" : 2}'::jsonb;
        jsonb
      ----------
       {"a": 2}
      (1 row)
       
       
    • 对于object-json,键值会重新进行排序,排序规则:长度长的在后、长度相等则ascii码大的在后,如:
      gaussdb=# SELECT '{"aa" : 1, "b" : 2, "a" : 3}'::jsonb;
                 jsonb
      --------------------------- 
      {"a": 3, "b": 2, "aa": 1}
      (1 row)
       
       
  • 大小比较

    由于经过了格式归一化,保证了同一种语义下的jsonb只会有一种存在形式,因此按照制定的规则,可以比较大小。

    • 首先比较类型:object-jsonb > array-jsonb > bool-jsonb > num-jsonb > str-jsonb > null-jsonb
    • 同类型则比较内容:
      • str-jsonb类型:依据text比较的方法,使用数据库默认排序规则进行比较,返回值正数代表大于,负数代表小于,0表示相等。
      • num-jsonb类型:数值比较。
      • bool-jsonb类型:true > false。
      • array-jsonb类型:长度长的 > 长度短的,长度相等则依次比较每个元素。
      • object-jsonb类型:长度长的 > 长度短的,长度相等则依次比较每个键值对,先比较键,然后比较值。
      说明:

      object-jsonb类型内比较时,使用的是格式整理后的最终结果进行比较,因此相对于直接的输入未必会很直观。

  • 创建索引、主键
    • BTREE索引

      ​ jsonb类型支持创建btree索引,支持创建主键。

  • 包含存在

    查询一个JSON之中是否包含某些元素,或者某些元素是否存在于某个JSON中是jsonb的一个重要能力。

    -- 简单的标量/原始值只包含相同的值。
    gaussdb=# SELECT '"foo"'::jsonb @> '"foo"'::jsonb;
     ?column? 
    ----------
     t
    (1 row)
    
    -- 左侧数组包含了右侧字符串。
    gaussdb=# SELECT '[1, "aa", 3]'::jsonb ? 'aa';
     ?column? 
    ----------
     t
    (1 row)
    
    -- 左侧数组包含了右侧的数组所有元素,顺序、重复不重要。
    gaussdb=# SELECT '[1, 2, 3]'::jsonb @> '[1, 3, 1]'::jsonb;
     ?column? 
    ----------
     t
    (1 row)
    
    -- 左侧object-json包含了右侧object-json的所有键值对。
    gaussdb=# SELECT '{"product": "PostgreSQL", "version": 9.4, "jsonb":true}'::jsonb @> '{"version":9.4}'::jsonb;
     ?column? 
    ----------
     t
    (1 row)
    
    -- 左侧数组并没有包含右侧的数组所有元素,因为左侧数组的三个元素为1、2、[1,3],右侧的为1、3。
    gaussdb=# SELECT '[1, 2, [1, 3]]'::jsonb @> '[1, 3]'::jsonb; 
     ?column? 
    ----------
     f
    (1 row)
    
    gaussdb=# SELECT '{"foo": {"bar": "baz"}}'::jsonb @> '{"bar": "baz"}'::jsonb; 
     ?column? 
    ----------
     f
    (1 row)
    
     
     

    相关的操作符请参见JSON/JSONB函数和操作符

  • 函数和操作符

    json/jsonb类型相关支持的函数和操作符请参见JSON/JSONB函数和操作符

更多详情请参考GaussDB 文档中心:https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/24.1.30/productdesc/qlh_03_0001.html

 

posted on 2025-05-30 09:41  数据库笔记  阅读(9)  评论(0)    收藏  举报