网站首页 > 教程分享 正文
访问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[] | data 有 a 或 b吗? | data ?| array['a','b'] |
?& text[] | data 有 a 和 b吗? | 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
相关函数很多,详细内容可查看官方技术手册或官网。
猜你喜欢
- 2024-10-25 PostgreSQL之慢SQL语句(如何解决慢sql)
- 2024-10-25 Postgresql语法(POSTGRESQL语法)
- 2024-10-25 python开发-操作postgresql数据库
- 2024-10-25 新手如何快速搭建多套PostgreSQL集群
- 2024-10-25 Postgresql基础操作实战(postgresql基础操作实战视频)
- 2024-10-25 一次近乎完美的PostgreSQL版本大升级实践
- 2024-10-25 数据库大师成长日记:您所不知道的PostgreSQL,值得收藏
- 2024-10-25 【PostgreSQL】AUTO_EXPLAIN - 慢速查询的日志执行计划
- 2024-10-25 postgresql安装及使用(postgresql安装使用)
- 2024-10-25 PostgreSQL系列(三):字符串类型操作(一)
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- css导航条 (66)
- sqlinsert (63)
- js提交表单 (60)
- param (62)
- parentelement (65)
- jquery分享 (62)
- check约束 (64)
- curl_init (68)
- sql if语句 (69)
- import (66)
- chmod文件夹 (71)
- clearinterval (71)
- pythonrange (62)
- 数组长度 (61)
- javafx (59)
- 全局消息钩子 (64)
- sort排序 (62)
- jdbc (69)
- php网页源码 (59)
- assert h (69)
- httpclientjar (60)
- postgresql conf (59)
- winform开发 (59)
- mysql数字类型 (71)
- drawimage (61)
本文暂时没有评论,来添加一个吧(●'◡'●)