设为首页 收藏本站
查看: 825|回复: 0

[经验分享] PostgreSQL 9.4: 新增 JSONB 数据类型

[复制链接]

尚未签到

发表于 2016-11-20 11:59:28 | 显示全部楼层 |阅读模式
         PostgreSQL9.4 新增 JSONB 数据类型, JSONB 同时属于 JSON (JavaScript Object Notation) 数据类型,jsonb 和 json 的输入数据几乎完全通用,最大的差别体现在效率上,json 存储的数据几乎和输入数据一样,存储的是未解析的数据,调用函数时使用效率较低; 而 jsonb 存储的是分解的 binary 格式数据,使用时不需要再解析了,因此使用上效率较高; 另一方面 json 在写入时较快,而 jsonb 写入时由于需要转换导致写入较慢。下面通过些简单的例子了解两者的差异。
  
--1 这个例子两者没啥差异
 
francs=> SELECT '[1, 2, "foo", null]'::json;
        json         
---------------------
 [1,2,"foo",null]
(1 row)
 
francs=> SELECT '[1, 2, "foo", null]'::jsonb;
        jsonb        
---------------------
 [1,2,"foo",null]
(1 row)

备注:  json 类型输出的内容和写入的内容一样,不会对输出的结果改变,而 jsonb不一样,看下面的例子。
 
--2 jsonb 输出内容顺序不一样
 
francs=> SELECT '{"bar": "baz", "balance": 7.77, "active":false}'::json;
                      json                       
-------------------------------------------------
 {"bar":"baz","balance":7.77,"active":false}
(1 row)
 
francs=> SELECT '{"bar": "baz", "balance": 7.77, "active":false}'::jsonb;
                      jsonb                       
--------------------------------------------------
 {"bar":"baz","active":false,"balance":7.77}
(1 row)

 
--3 jsonb: 整数类型输出不一样
 
francs=> SELECT '{"reading": 1.230e-5}'::json,'{"reading": 1.230e-5}'::jsonb;
         json          |          jsonb          
-----------------------+-------------------------
 {"reading":1.230e-5}|{"reading":0.00001230}
(1 row)

 
--4 jsonb: 去掉了空格
 
francs=>select' {"id":1,
"name":"francs",
"remark":"a good guy!"
}'::json;
          json          
------------------------
  {"id":1,             +
 "name":"francs",      +
 "remark":"a good guy!"+
 }
(1 row)
 
francs=>select' {"id":1,
"name":"francs",
"remark":"a good guy!"
}'::jsonb;
                        jsonb                         
------------------------------------------------------
 {"id":1,"name":"francs","remark":"a good guy!"}
(1 row)

 
--5 jsonb:  重复的元素值仅保留最后一个
 
francs=>select' {"id":1,
"name":"francs",
"remark":"a good guy!",
"name":"test"
}'::jsonb;
                       jsonb                        
----------------------------------------------------
 {"id":1,"name":"test","remark":"a good guy!"}
(1 row)

备注: json 类型的输出和输入一样,会保留所有重复的元素,而 jsonb 对于重复的元素仅保留最后出现的重复元素。
 
 
--6 关于索引
 
  GIN  索引支持 jsonb 类型,支持大的 jsonb 表中基于 keys 或者 key/values 模式的检索。
   默认的 GIN 索引模式支持带有 @>, ?, ?& 和 ?| 操作的查询,关于这些操作符的含义参考本文的附录。
  
 假如有一个文档:
 
{
    "guid":"9c36adc1-7fb5-4d5b-83b4-90356a46061a",
    "name":"Angela Barton",
    "is_active":true,
    "company":"Magnafone",
    "address":"178 Howard Place, Gulf, Washington, 702",
    "registered":"2009-11-07T08:53:22 +08:00",
    "latitude":19.793713,
    "longitude":86.513373,
    "tags":[
        "enim",
        "aliquip",
        "qui"
    ]
}

 
我们将表名定义为 api,  jsonb 字段为 jdoc,创建如下索引
CREATE INDEX idx_gin_api_jdoc ON api USING gin (jdoc);

 
那么如下的查询可以使用索引
 
--Find documents in which the key "company" has value "Magnafone"
SELECT jdoc->'guid', jdoc->'name' FROM api WHERE jdoc @>'{"company": "Magnafone"}';

备注:上面这个例子来自手册。
 
7 附 Additional jsonb Operators
OperatorRight Operand TypeDescriptionExample=jsonbAre the two JSON values equal?'[1,2,3]'::jsonb = '[1,2,3]'::jsonb@>jsonbDoes the left JSON value contain within it the right value?'{"a":1, "b":2}'::jsonb @> '{"b":2}'::jsonb<@jsonbIs the left JSON value contained within the right value?'{"b":2}'::jsonb <@ '{"a":1, "b":2}'::jsonb?textDoes the key/element string exist within the JSON value?'{"a":1, "b":2}'::jsonb ? 'b'?|text[]Do any of these key/element strings exist?'{"a":1, "b":2, "c":3}'::jsonb ?| array['b', 'c']?&text[]Do all of these key/element strings exist?'["a", "b"]'::jsonb ?& array['a', 'b']
 

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-302909-1-1.html 上篇帖子: Postgresql 连表更新字段语法 update 下篇帖子: PostgreSQL主键膨胀使用CONCURRENTLY维护
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表