程序员的知识教程库

网站首页 > 教程分享 正文

PostgreSQL JSON 类型数据的基本用法

henian88 2024-10-25 11:47:59 教程分享 2 ℃ 0 评论

访问Json类型数据

SELECT * FROM users WHERE data->>'name' = 'John';
SELECT data->>'name' AS name FROM users;

运算符

说明

示例

返回值

-> int

获取数组元素 2

data->2

JSON

-> text

获取对象主键 name

data->'name'

JSON

#> text[]

获取主键路径 a,b (如, data.a.b)

data#>'{a,b}'

JSON

->> int

获取数组元 2

data->>2

Text

->> text

获取对象主键 name

data->>'name'

Text

#>> text[]

获取主键将路径 a,b (如, data.a.b)

data#>>'{a,b}'

Text

> returns JSON(返回Json格式)

>> returns text (返回文本)

逻辑运算符

SELECT * FROM users WHERE data->tags ? 'admin';
SELECT data->tags ? 'admin' AS is_admin FROM users;

运算符

说明

示例

? str

data 有主键 name吗?

data ? 'name'

?| text[]

dataab吗?

data ?| array['a','b']

?& text[]

dataab吗?

data ?& array['a','b']

@> jsonb

是否为左包含?

data @> '{"b":2}'::jsonb

<@ jsonb

是否为有包含?

data <@ '{"a":1,"b":2}'::jsonb

注意,如果 ?/?|/?& 的运算目标是对象, 就会检查主键; 如果运算对象是数组, 会检查数组中的元素。

更新数组和对象

UPDATE users SET tags = tags || array['admin'];

运算符

示例

说明

|| json

data || array['a','b']

拼接

- str

data - 'a'

删除主键

- int

data - 1

删除数组的一个元素

#- text[]

data #- '{us,name}'

删除路径

UPDATE users SET data = jsonb_set(data, '{name}', '"John"');

注意,以上方法在 PostgreSQL 9.5+有效。

与Json数据类型相关的函数

fn(json) → json

jsonb_set(data, '{path}', value)
jsonb_strip_nulls(data)

fn(···) → json

to_json("Hello"::text)
array_to_json('{1,2}'::int[])

Iteration

SELECT * from json_each('{"a":1, "b":2}')
SELECT * from json_each_text('{"a":1, "b":2}')
-- key | value

相关函数很多,详细内容可查看官方技术手册或官网。

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

最近发表
标签列表