GBase 8c 数据类型-JSON/JSONB类型

JSON(JavaScript Object Notation)数据,可以是单独的一个标量,也可以是一个数组,也可以是一个键值对象。其中数组和对象可以统称容器(container):

l 标量(scalar):单一的数字、bool、string、null都可以叫做标量。

l 数组(array):[]结构,里面存放的元素可以是任意类型的JSON,并且不要求数组内所有元素都是同一类型。

l 对象(object):{}结构,存储key:value的键值对,其键只能是用“”包裹起来的字符串,值可以是任意类型的JSON,对于重复的键,按最后一个键值对为准。

GBase 8c支持两种存储JSON数据的类型:JSON和JSONB。其中JSON是对输入的字符串的完整拷贝,使用时再去解析,所以它会保留输入的空格、重复键以及顺序等;JSONB解析输入后保存的二进制,它在解析时会删除语义无关的细节和重复的键,对键值也会进行排序,使用时不用再次解析。

二者接受输入相同的字符串。但差别在于处理效率:JSON数据类型存储输入文本的精确拷贝,处理函数必须在每个执行上重新解析;而JSONB数据类型以分解的二进制格式存储,这使得由于转换机制而在输入过程略慢些,但是在处理过程明显更快,因为不需要重新解析。同时,由于JSONB类型存在解析后的格式归一化等操作,同等语义下只会有一种格式。因此,JSONB能够更好地支持一些额外操作,如按照特定规则进行大小比较等。此外,JSONB还支持索引。

输入格式

输入必须是一个符合JSON数据格式的字符串,此字符串用单引号''声明。

null (null-json):仅null,全小写。

gbase=# select 'null'::json;

json

------

 null

(1 row)

gbase=# select 'NULL'::jsonb;

ERROR:  invalid input syntax for type json

LINE 1: select 'NULL'::jsonb;

               ^

DETAIL:  Token "NULL" is invalid.

CONTEXT:  JSON data, line 1: NULL

referenced column: jsonb

数字 (num-json):正负整数、小数、0,支持科学计数法。

gbase=# select '1'::json;

json

------

 1

(1 row)

gbase=# select '-1.5'::json;

json

------

 -1

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值