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'asnickname; #使用->>返回结果不带引号 select'{"nickname":"goodspeed","avatar":"avatar_url","tags":["python","golang","db"]}'::json->>'nickname'asnickname;
复杂查询
#{tags,0}代表查询key=‘tags',且value为数组中数组的第一个元素 select'{"nickname":"gs","avatar":"avatar_url","tags":["python","golang","db"]}'::json#>'{tags,0}'astag; #{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(原数据,需要更改的位置,替换的值,是否不存在时新增), selectjsonb_set('[{"f1":1,"f2":null},2,null,3]','{0,f1}','[2,3,4]',false);
到此这篇关于postgresql的jsonb数据查询和修改的文章就介绍到这了,更多相关postgresqljsonb数据查询和修改内容请搜索毛票票以前的文章或继续浏览下面的相关文章希望大家以后多多支持毛票票!
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。