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

做润滑油网站图片百度推广公司哪家比较靠谱

做润滑油网站图片,百度推广公司哪家比较靠谱,wordpress 附件管理,公司简介宣传册图片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://www.dtcms.com/wzjs/147220.html

相关文章:

  • 教人做甜品的网站搜索引擎下载安装
  • 网络推广100种方法网络推广渠道有哪些天津seo技术教程
  • ps做网站百度应用平台
  • 采集网站如何收录汕头seo关键词排名
  • 合肥解封最新消息抖音关键词排名优化软件
  • 深圳工程建设交易中心网高级seo培训
  • 微信优惠券网站怎么做的软文广告代理平台
  • 接网站建设的单子杭州免费网站制作
  • 两个男性做网站市场调研分析报告模板
  • 做景观私活的网站公关公司的主要业务
  • 网站开发人员要求seo课程培训中心
  • 找人做设计的网站电商运营方案
  • 企业网站一年多少钱惠州百度seo在哪
  • 广东网站定制网上销售有哪些方法
  • 各类服装网站建设网站关键词免费优化
  • 湖南人文科技学院搜索引擎优化的技巧
  • 个人做网站怎么备案精准营销推广
  • 阿里巴巴能拿货在家里做的网站网店运营推广实训
  • 衡水高端网站建设网络营销的特点包括
  • 网站维护后期费用seo竞价排名
  • 网站建设具体实施方案广告优化师是做什么的
  • 单页网页设计图片安徽网络关键词优化
  • centos建设网站百度seo排名优化公司哪家好
  • uilike学堂快手seo关键词优化
  • 在本地搭建wordpress东莞百度快照优化排名
  • 怎么开通网站泉州seo培训
  • 委外网站开发合同模板浏览器打开网站
  • 未来销售最好的行业seoul是啥意思
  • 哈尔滨网站建设多少钱站长之家seo工具
  • 做精神科网站手机百度ai入口