PostgreSql中解析JSON字段和解析TEXT中的JSON字段

初始化操作

创建表

csharp 复制代码
CREATE TABLE orders (  "ID" int8 NOT NULL,
                       "info_j" json NOT NULL,
                       "info_t" text NOT NULL
);

初始化表

csharp 复制代码
INSERT INTO orders("ID", "info_j","info_t") VALUES (1, '{"name":"张三","items":{"product":"啤酒","qty":6}}','{"name":"张三","items":{"product":"啤酒","qty":6}}');
INSERT INTO orders("ID", "info_j","info_t") VALUES (2, '{"name":"李四","items":{"product":"辣条","qty":8}}','{"name":"李四","items":{"product":"辣条","qty":8}}');
INSERT INTO orders("ID", "info_j","info_t") VALUES (3, '{"name":"王五","items":{"product":"苹果","qty":18}}','{"name":"王五","items":{"product":"苹果","qty":18}}');
INSERT INTO orders("ID", "info_j","info_t") VALUES (4, '{"name":"赵一","items":{"product":"香蕉","qty":20}}','{"name":"赵一","items":{"product":"香蕉","qty":20}}');

查询表

解析JSON字段

查询使用->操作符,查询json中所有顾客作为键

csharp 复制代码
SELECT info_j -> 'name' AS customer FROM orders;

下面使用->>操作获取所有顾客姓名作为值

csharp 复制代码
SELECT info_j ->> 'name' AS customer FROM orders;

根据json对象的key查询值

csharp 复制代码
SELECT info_j -> 'items' ->> 'product' AS customer FROM orders;

解析TEXT中的JSON字段

其实和解析JSON字段一样我们只需要加上::json


相关推荐
捧月华如23 分钟前
RAG 入门-向量存储与企业级向量数据库 milvus
数据库·milvus
杨云龙UP1 小时前
Oracle Data Pump实战:expdp/impdp常用参数与导入导出命令整理_20260406
linux·运维·服务器·数据库·oracle
想唱rap1 小时前
线程池以及读写问题
服务器·数据库·c++·mysql·ubuntu
爱丽_2 小时前
B+ 树范围查询为什么快:页分裂/合并、索引设计与 SQL 写法优化
数据库·算法·哈希算法
better_liang3 小时前
每日Java面试场景题知识点之-MySQL索引
java·数据库·mysql·性能优化·索引
AgCl233 小时前
MYSQL-4-DQL数据查询语言-3/14-15
数据库·mysql
别抢我的锅包肉3 小时前
【MySQL】第五节 - 事务实战详解:从基础到并发控制(附 Navicat 可运行实验脚本)
数据库·mysql
AgCl233 小时前
MYSQL-5-DCL数据查询语言-3/16
数据库·mysql
IvorySQL3 小时前
PostgreSQL 技术日报 (4月7日)|内核开发新动态,多项功能优化落地
数据库·postgresql·开源
IvorySQL4 小时前
PostgreSQL 技术日报 (4月6日)|内核补丁与性能优化速递
数据库·postgresql·开源