当前位置: 首页 > wzjs >正文

看网站的关键词汽车最好网站建设

看网站的关键词,汽车最好网站建设,服装设计好找工作吗,服装设计考研哪些大学PostgreSQL JSON 和 JSONB 查询示例 PostgreSQL 支持 JSON 和 JSONB 两种 JSON 类型: JSON:存储为 纯文本,查询时需要解析,效率较低。JSONB:存储为 二进制格式,支持索引,查询性能更好。 下面…

PostgreSQL JSONJSONB 查询示例

PostgreSQL 支持 JSONJSONB 两种 JSON 类型:

  • JSON:存储为 纯文本,查询时需要解析,效率较低。
  • JSONB:存储为 二进制格式,支持索引,查询性能更好。

下面分别列出 JSONJSONB 的查询示例。

一、JSON 查询示例

创建 JSON 类型的表:

CREATE TABLE demo_json (id SERIAL PRIMARY KEY,params JSON
);

插入数据:

INSERT INTO demo_json (params) VALUES 
('{"name": "Alice", "age": 25, "is_active": true, "skills": ["Java", "SQL"], "address": {"city": "New York", "zip": 10001}, "salary": null}'),
('{"name": "Bob", "age": 30, "is_active": false, "skills": ["Python", "Go"], "address": {"city": "Los Angeles", "zip": 90001}, "salary": 5000}');

1. 查询 JSON 数据

(1) 查询 JSON 整个对象
SELECT params FROM demo_json;
(2) 查询 JSON 中的某个键
SELECT params->'name' FROM demo_json;

🔹 -> 返回 JSON 类型。

SELECT params->>'name' FROM demo_json;

🔹 ->> 返回 TEXT 类型(更适合查询)。

(3) 查询 JSON 数组中的元素
SELECT params->'skills'->0 FROM demo_json;

🔹 获取数组中的第一个元素。


2. 过滤 JSON 数据

(4) 查询 JSON 中包含某个值
SELECT * FROM demo_json WHERE params->>'name' = 'Alice';
(5) 查询 JSON 数字值
SELECT * FROM demo_json WHERE (params->>'age')::INT > 25;
(6) 查询 JSON 布尔值
SELECT * FROM demo_json WHERE (params->>'is_active')::BOOLEAN = true;
(7) 查询 JSON 中 null
SELECT * FROM demo_json WHERE params->>'salary' IS NULL;

3. JSON 不能索引,查询较慢

CREATE INDEX idx_json_name ON demo_json ((params->>'name'));

🔹 JSON 本身不支持索引,必须用 表达式索引 才能加速查询。


二、JSONB 查询示例

创建 JSONB 类型的表:

CREATE TABLE demo_jsonb (id SERIAL PRIMARY KEY,params JSONB
);

插入数据:

INSERT INTO demo_jsonb (params) VALUES 
('{"name": "Alice", "age": 25, "is_active": true, "skills": ["Java", "SQL"], "address": {"city": "New York", "zip": 10001}, "salary": null}'),
('{"name": "Bob", "age": 30, "is_active": false, "skills": ["Python", "Go"], "address": {"city": "Los Angeles", "zip": 90001}, "salary": 5000}');

1. 查询 JSONB 数据

(1) 查询 JSONB 整个对象
SELECT params FROM demo_jsonb;
(2) 查询 JSONB 中的某个键
SELECT params->'name' FROM demo_jsonb;
SELECT params->>'name' FROM demo_jsonb;

🔹 区别

  • -> 返回 JSONB(适用于嵌套查询)。
  • ->> 返回 TEXT(适用于筛选)。
(3) 查询 JSONB 数组中的元素
SELECT params->'skills'->0 FROM demo_jsonb;

2. 过滤 JSONB 数据

(4) 查询 JSONB 中包含某个值
SELECT * FROM demo_jsonb WHERE params->>'name' = 'Alice';
(5) 查询 JSONB 数字值
SELECT * FROM demo_jsonb WHERE (params->>'age')::INT > 25;
(6) 查询 JSONB 布尔值
SELECT * FROM demo_jsonb WHERE (params->>'is_active')::BOOLEAN = true;
(7) 查询 JSONB 中 null
SELECT * FROM demo_jsonb WHERE params->>'salary' IS NULL;

3. JSONB 独有的高级查询

(8) 使用 @> 进行 JSONB 包含查询
SELECT * FROM demo_jsonb WHERE params @> '{"age": 25}';

🔹 查询 params 是否包含 {"age": 25}

(9) 查询 JSONB 数组是否包含某个值
SELECT * FROM demo_jsonb WHERE params->'skills' ? 'Java';

🔹 ? 用于数组包含查询

(10) 查询 JSONB 数组是否包含多个值
SELECT * FROM demo_jsonb WHERE params->'skills' ?| array['Java', 'Python'];

🔹 ?| 表示包含至少一个

SELECT * FROM demo_jsonb WHERE params->'skills' ?& array['Java', 'SQL'];

🔹 ?& 表示包含所有


4. JSONB 更新

(11) 更新 JSONB 的某个值
UPDATE demo_jsonb 
SET params = jsonb_set(params, '{age}', '40') 
WHERE params->>'name' = 'Alice';

🔹 更新 age 字段为 40

(12) 更新 JSONB 中的嵌套对象
UPDATE demo_jsonb 
SET params = jsonb_set(params, '{address, city}', '"Chicago"') 
WHERE params->>'name' = 'Alice';

🔹 更新 address.cityChicago


5. JSONB 索引(查询更快)

CREATE INDEX idx_jsonb_name ON demo_jsonb USING GIN (params);

🔹 JSONB 支持 GIN 索引,加速查询!


总结

对比项JSONJSONB
存储格式纯文本二进制
查询性能解析时才转换,较慢直接查询,较快
索引支持仅支持表达式索引支持 GIN 索引
包含查询params->>'name' = 'Alice'params @> '{"name": "Alice"}'
更新单个键需更新整个 JSONjsonb_set() 可更新部分
数组查询不支持 ? 操作符支持 params->'skills' ? 'Java'

🔹 JSONB 更适用于查询频繁的数据,尤其是带索引的查询。
🔹 JSON 适用于存储但不做复杂查询的数据。

🚀 结论:如果要查询 JSON 数据,推荐使用 JSONB


文章转载自:

http://EHv6fzZo.nLdsd.cn
http://I0EPJEEI.nLdsd.cn
http://AH5mwdjf.nLdsd.cn
http://a3FVMBGA.nLdsd.cn
http://9RoEjAap.nLdsd.cn
http://2UuYGvT8.nLdsd.cn
http://9qnjDToZ.nLdsd.cn
http://VAV6e7iN.nLdsd.cn
http://UJxBysij.nLdsd.cn
http://n6xz9RaC.nLdsd.cn
http://lGSwgPxm.nLdsd.cn
http://oWBfd87C.nLdsd.cn
http://YsFlXPKX.nLdsd.cn
http://4St38btm.nLdsd.cn
http://ckvTv34Y.nLdsd.cn
http://vldzcZr6.nLdsd.cn
http://pGtafqfB.nLdsd.cn
http://NkAv4pzD.nLdsd.cn
http://okmeAl6E.nLdsd.cn
http://cD5lZPzA.nLdsd.cn
http://H6pexfYl.nLdsd.cn
http://7u0Y0lWZ.nLdsd.cn
http://3yAtsWv6.nLdsd.cn
http://TCulWLvg.nLdsd.cn
http://NujZqnvk.nLdsd.cn
http://0nBCeGhr.nLdsd.cn
http://wiR0yX3q.nLdsd.cn
http://bWUoCe4G.nLdsd.cn
http://PIuEk8id.nLdsd.cn
http://maAPQ9iR.nLdsd.cn
http://www.dtcms.com/wzjs/744963.html

相关文章:

  • 南通网站建设规划如何开通网上商城
  • 北京信管局 网站备案网站开发教程全集
  • 郑州网站seo顾问容桂网站制作代理
  • 网站建设网站维护卖酒网站排名
  • 注册网站时应注意什么广州制作网站的公司
  • 成都企业网站建设哪家好手机维修培训班学校
  • 芒市网站建设自己做一个音乐网站怎么做
  • 广东汽车品牌网站建设网页模板版权申请
  • 应聘网站运营建设面试电子商务网站建设详细策划
  • 北海市建设局官方网站网站策划书ppt
  • 西安网站建设招标跨境电商怎么做视频教程
  • 网站建设跟版网wordpress新窗口打开所有外链
  • 网站开发总体流程图公司取名大全最新版的
  • 外国优秀网站wordpress自定义小工具
  • 山西省建设注册中心网站减粘装置设备设计要点
  • 保利建设开发总公司网站企业有域名怎么做网站
  • 山西做网站贵吗网站打开速度多少时间
  • 做图用哪个素材网站海南做网站的技术公司
  • 工商银行门户网站是什么意思广州天河区建设网站公司
  • html 网站建设中模板wordpress站点地址灰显
  • 德州市建设工程质监站网站卡片式网站
  • 阿里云网站校园网络设计
  • 个旧建设局信息公开门户网站旅游电子商务网站建设的流程
  • 江苏省建设厅网站职称评审系统网站开发用什么软件有哪些
  • wordpress博客收录查询网站建设企业网站优化
  • 做印刷品的素材网站国外对企业网站开发的研究
  • 济宁建设局网站首页购物网站建设的选题意义
  • 为什么要用php做网站cms三合一网站源码
  • 高新区做网站程序员接单网站
  • 找建设项目的网站网站高端建设