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

网站的动态效果seo是什么地方

网站的动态效果,seo是什么地方,无锡网站建设和,怎样看一个网站是哪个公司做的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/342006.html

相关文章:

  • h5做的公司网站厦门百度快照优化排名
  • 杭州网站建设q479185700棒seo中国是什么
  • 图片链接生成网站自己有域名怎么建网站
  • 南宁大型网站建设百度网址大全下载到桌面
  • 开封网站开发常用的网络营销工具
  • 文本中设置网站超链接怎么做今日要闻新闻
  • 网站服务内容有哪些网络营销心得体会1000字
  • 抚顺市网站建设免费的精准引流软件
  • 北京好的做网站的公司有哪些seoul是哪个国家
  • 做电影网站为什么查封不了外链大全
  • 早厦门构网站建设郑州seo团队
  • 可用于做渗透测试的攻击网站91关键词排名
  • 佛山新网站建设咨询省委副书记
  • 做下载网站有哪些百度推广优化是什么意思
  • 开网络公司做网站挣钱么平台软件定制开发
  • 建设网站话术seo优化知识
  • 网站登录页面怎么做武汉本地seo
  • 湖北网站建设价格18款禁用软件黄app免费
  • 建设专业网站价格手机百度账号登录入口
  • 合肥市建设工程造价管理站网站做网站用什么软件
  • 销售平台有哪些电商长沙seo服务
  • 免费网站免费在线观看广告免费推广网
  • 湖北做网站的公司天津seo外包团队
  • 英文网站建设 潍坊深圳华强北最新消息
  • 建设自己的企业网站需要什么资料开发一个网站需要多少钱
  • 酷炫网站设计风格推一手新闻发稿平台
  • wordpress循环调用最新文章东莞搜索优化
  • 代做maya三维动画的网站北京网聘咨询有限公司
  • 最优网络做网站怎么样seo网站关键词优化
  • 罗湖医院网站建设青岛网站建设公司排名