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

PostgreSQL的Json数据类型如何使用

PostgreSQL中的JSON数据类型提供了一种灵活的方式来存储JSON(JavaScript Object Notation)数据。JSON是一种轻量级的数据交换格式,易于人阅读和编写,同时也易于机器解析和生成。在PostgreSQL中,你可以使用JSON和JSONB(JSON的二进制格式,支持索引和更快的查询)数据类型来存储JSON数据。

1. 创建包含JSON列的表

首先,你可以在创建表时指定一个列使用JSON或JSONB数据类型。

CREATE TABLE test_table (  id int4 PRIMARY KEY,  info JSONB  
);

在这个例子中,example表有一个自增的主键id和一个data列,该列使用JSONB数据类型。

2. 插入JSON数据

你可以像插入普通文本一样插入JSON数据,只需确保数据是有效的JSON格式。

INSERT INTO test_table (id, info) VALUES  
(1, '{"name": "John", "age": 30, "city": "New York"}'),  
(2, '{"name": "Jane", "age": 25, "city": "Los Angeles"}');

3. 查询 JSON 数据

PostgreSQL 提供了多种操作符和函数来查询 JSON 数据。

  • 使用 ->> 操作符获取文本值
    SELECT info->>'name' AS name FROM test_table;
  • 使用 -> 操作符获取 JSON 对象
    SELECT info->'skills' AS skills FROM test_table WHERE info->>'name' = 'Jane Smith';

    注意,-> 返回的是 JSON 或 JSONB 类型的值,而 ->> 返回的是文本(如果值是字符串的话)。

  • 使用 jsonb_array_elements 函数遍历 JSON 数组
    SELECT name, skill  
    FROM test_table,  jsonb_array_elements_text(info->'skills') AS skill(skill)  
    WHERE info->>'name' = 'Jane Smith';

    这里使用了 jsonb_array_elements_text 而不是 jsonb_array_elements,因为后者返回的是 JSONB 类型的数组元素,而前者直接返回文本。

  • 使用 jsonb_each 函数遍历 JSON 对象
SELECT id, key, value->>'text' AS value  
FROM test_table,  jsonb_each(info) AS x(key, value)  
WHERE info->>'name' = 'John Doe';

这里,jsonb_each 函数遍历 info 列中的每个键值对,并将它们作为行返回。

4. 更新 JSON 数据

你可以使用 jsonb_set 函数来更新 JSONB 数据中的特定字段。

UPDATE test_table  
SET info = jsonb_set(info, '{age}', '"31"')  
WHERE id = 1;

5. 使用 JSONB 索引

由于 JSONB 支持索引,你可以对 JSONB 列中的特定字段创建索引以提高查询性能。

CREATE INDEX idx_my_table_info_name ON test_table USING gin ((info->>'name'));

但是,请注意,上面的索引实际上是对文本字段的索引,而不是对 JSONB 内部结构的直接索引。对于更复杂的查询,你可能需要使用表达式索引或 GIN/GiST 索引来索引 JSONB 对象中的嵌套数据。

CREATE INDEX idx_my_table_info_jsonb ON test_table USING gin (info jsonb_path_ops);

这个索引使用 jsonb_path_ops 操作符类,它适用于基于路径的查询。

数据库版本确实是 PostgreSQL 9.2 或更高版本

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • Flask校验
  • Ansible服务实现自动化运维
  • 微信小程序开发入门指南
  • 在STM32嵌入式中C/C++语言对栈空间的使用
  • Matlab Git管理
  • shell 条件语句
  • 不同类型的指针变量进行++操作的效果
  • allure_pytest:AttributeError: ‘str‘ object has no attribute ‘iter_parents‘
  • MongoDB文档整理
  • JavaScript:节流与防抖
  • 主页目录导航
  • Unity XR Interaction Toolkit(VR、AR交互工具包)记录安装到开发的流程,以及遇到的常见问题(一)!
  • 如何将PDF转换成可以直接编辑的CAD图纸?
  • 前端下载文件流 出现乱码 解决方案
  • Random,ThreadLocalRandom,SecureRandom有什么区别
  • 【每日笔记】【Go学习笔记】2019-01-10 codis proxy处理流程
  • DOM的那些事
  • Elasticsearch 参考指南(升级前重新索引)
  • Linux Process Manage
  • MySQL-事务管理(基础)
  • node.js
  • PAT A1092
  • ReactNativeweexDeviceOne对比
  • Synchronized 关键字使用、底层原理、JDK1.6 之后的底层优化以及 和ReenTrantLock 的对比...
  • vue-router的history模式发布配置
  • 对话 CTO〡听神策数据 CTO 曹犟描绘数据分析行业的无限可能
  • 基于游标的分页接口实现
  • 使用 @font-face
  • 新书推荐|Windows黑客编程技术详解
  • 最简单的无缝轮播
  • ​【经验分享】微机原理、指令判断、判断指令是否正确判断指令是否正确​
  • # 达梦数据库知识点
  • #git 撤消对文件的更改
  • #Spring-boot高级
  • #systemverilog# 之 event region 和 timeslot 仿真调度(十)高层次视角看仿真调度事件的发生
  • #在线报价接单​再坚持一下 明天是真的周六.出现货 实单来谈
  • (13)Latex:基于ΤΕΧ的自动排版系统——写论文必备
  • (7)svelte 教程: Props(属性)
  • (AngularJS)Angular 控制器之间通信初探
  • (DFS + 剪枝)【洛谷P1731】 [NOI1999] 生日蛋糕
  • (动手学习深度学习)第13章 计算机视觉---微调
  • (附源码)ssm高校志愿者服务系统 毕业设计 011648
  • (力扣)1314.矩阵区域和
  • (六)DockerCompose安装与配置
  • (深入.Net平台的软件系统分层开发).第一章.上机练习.20170424
  • (十六)一篇文章学会Java的常用API
  • (十三)MipMap
  • (学习日记)2024.03.25:UCOSIII第二十二节:系统启动流程详解
  • (转)Android中使用ormlite实现持久化(一)--HelloOrmLite
  • (转)PlayerPrefs在Windows下存到哪里去了?
  • ****** 二 ******、软设笔记【数据结构】-KMP算法、树、二叉树
  • .gitignore文件_Git:.gitignore
  • .NET 5种线程安全集合
  • .NET CLR Hosting 简介
  • .net core 外观者设计模式 实现,多种支付选择