从PostgreSQL 9.3开始,json就成了postgres里的一种数据类型,也就是和varchar、int一样,我们表里的一个字段的类型可以为json了。
于此同时,postgres还提供了jsonbs格式,jsonb格式是json的二进制形式,二者的区别在于json写入快,读取慢,jsonb写入慢,读取快,但在操作上,二者是没有区别的。下面以jsonb为例。
创建表
假设我们要存储的json数据是这样的:
{
"id":ID
"name":"名字",
"年龄":年龄
}
建表语句如下:
create table if not exists name_age{ info jsonb }
好了,这样就创建了一张表,里面只有一个 info 字段,下面开始进行CRUD操作。
插入数据
插入数据可以直接以json格式插入:
insert into name_age values('{"id":1,"name":"小明","age":18}')
在json里插入新的key值gender,如下:
SELECT info || '{"gender":"男"}'::jsonb FROM name_age WHERE (info->>'id')::int4 = 1
查询数据
postgres里的查询需要用到查询符。比如说,我们要查询id为1的数据,语句如下:
select info from name_age where info @>'{"id":1}'::jsonb
用到了 @> 这个查询符,表明info当前这条记录里的顶层json中有没有id为1的key-value对;有的话则满足条件。