什么是jsonb
由PostgreSQL文档定义的数据类型json和jsonb几乎相同;关键的区别在于json数据存储为JSON输入文本的精确副本,而jsonb以分解的二进制形式存储数据;也就是说,不是ASCII / UTF-8字符串,而是二进制代码。
本文主要讲的是如何随心所欲的查询和修改postgresql中jsonb格式的数据
一、查询
简单查询
1
2
3
4
5
|
# 存储的是 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;
|
复杂查询
1
2
3
4
|
# {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}';
|
二、修改
修改
1
2
|
jsonb_set(原数据, 需要更改的位置, 替换的值,是否不存在时新增),
select jsonb_set( '[{"f1":1,"f2":null},2,null,3]' , '{0,f1}' , '[2,3,4]' , false );
|
到此这篇关于postgresql的jsonb数据查询和修改的文章就介绍到这了,更多相关postgresql jsonb数据查询和修改内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://blog.csdn.net/weixin_45807440/article/details/112626751