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


相关推荐
缘友一世30 分钟前
macos安装mongodb
数据库·mongodb·macos
万事大吉CC2 小时前
mysql单表查询·3
数据库·mysql
bin91532 小时前
【EXCEL数据处理】000010 案列 EXCEL文本型和常规型转换。使用的软件是微软的Excel操作的。处理数据的目的是让数据更直观的显示出来,方便查看。
大数据·数据库·信息可视化·数据挖掘·数据分析·excel·数据可视化
Miqiuha3 小时前
lock_guard和unique_lock学习总结
java·数据库·学习
一 乐4 小时前
学籍管理平台|在线学籍管理平台系统|基于Springboot+VUE的在线学籍管理平台系统设计与实现(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·学习
Java探秘者7 小时前
Maven下载、安装与环境配置详解:从零开始搭建高效Java开发环境
java·开发语言·数据库·spring boot·spring cloud·maven·idea
2301_786964367 小时前
3、练习常用的HBase Shell命令+HBase 常用的Java API 及应用实例
java·大数据·数据库·分布式·hbase
阿维的博客日记8 小时前
图文并茂解释水平分表,垂直分表,水平分库,垂直分库
数据库·分库分表
ZhongruiRao9 小时前
Springboot+PostgreSQL+MybatisPlus存储JSON或List、数组(Array)数据
spring boot·postgresql·json
wrx繁星点点9 小时前
事务的四大特性(ACID)
java·开发语言·数据库