Oracle/PL/SQL奇技淫巧之Json转表

在Oracle中,有些时候我们需要在一个json文档中查数据

这个时候我们可以通过JSON_TABLE函数来把 json文档 提取成一张可以执行正常查询操作的表

先看JSON_TABLE函数的基础用法:

sql 复制代码
JSON_TABLE(json_data, '$.json_path' COLUMNS (column_definitions))

其中:
json_data:要从中提取数据的 JSON文档 或 JSON列
$.json_path:JSON路径表达式,该表达式指定要提取的数据的位置
COLUMNS子句:定义要从JSON数据中提取的列,每个列定义都应该包括列名、数据类型和JSON路径表达式,以指定数据在JSON文档中的位置。

例:

sql 复制代码
SELECT *
FROM JSON_TABLE('{"name": "John", "age": 30, "city": "New York"}',
                '$' COLUMNS (name VARCHAR2(50) PATH '$.name_',
                         	 age NUMBER PATH '$.age_',
                         	 city VARCHAR2(50) PATH '$.city_'));

这里的json_data='{"name": "John", "age": 30, "city": "New York"}'
$的含义是从JSON文档的根路径提取数据
COLUMNS子句表示将从JSON文档中提取name_age_city_这三列数据分别放入nameagecity列中

注意()中的$表示的路径是基于COLUMNS 前面指定的那个路径,这里是$.$

函数的结果将是一个包含三列的表:nameagecity,其中包含从JSON文档中提取的相应值。

如果JSON文档是一个JSON数组呢?

例如有这样一个json_list文档:

json 复制代码
[
  {
    "count": "2",
    "items": [
      {
        "key": "keyOne",
        "value": "valueOne"
      },
      {
        "key": "keyTwo",
        "value": "valueTwo"
      }
    ]
  }
]

虽然里面只有一个JSON对象,但是这个JSON文档是一个JSON数组,用[]包起来的

看看怎么解析它:

sql 复制代码
 json_table(json_list, 
 			'$[*]' columns (colum_1 VARCHAR2(20) PATH '$.count',
                     		colum_2 VARCHAR2(1000) FORMAT JSON PATH '$.count'));

$[*]的含义是从JSON数组[]里面提取数据,*表示所有元素
COLUMNS子句表示将从JSON文档中提取countcount这两列数据分别放入colum_1colum_2列中

注意columns ()中的$表示的路径是基于COLUMNS 前面指定的那个路径,在这里就是$[*].$

函数的结果将是一个包含两列的表:colum_1colum_2

路径格式:

  1. 取所有元素:$[*],表示取所有元素;
  2. 取指定单个元素:如'$[0]',表示取第一个元素;
  3. 取指定多个元素:如$[0, 2, 4],表示取第一、三、五个元素;
  4. 取范围连续元素:如$[0 TO 2],表示取第一到第三个元素;

如果不指定元素,如$[],则会报错

相关推荐
麦聪聊数据11 小时前
企业数据流通与敏捷API交付实战(五):异构数据跨库联邦与零代码发布
数据库·sql·低代码·restful
杨云龙UP11 小时前
Oracle 中 NOMOUNT、MOUNT、OPEN 怎么理解? 在不同场景下如何操作?_20260402
linux·运维·数据库·oracle
bloglin9999913 小时前
掌握解析JSON输出的技巧:使用LLM生成结构化数据
json
生瓜硬劈..13 小时前
SQL 调优全解:从 20 s 到 200 ms 的 6 步实战笔记
java·笔记·sql
颜颜yan_13 小时前
让数据库学会说“不“——金仓 SQL 防火墙深度解析
数据库·sql
霖霖总总13 小时前
[小技巧52]从 SQL 到结果:MySQL 8.0 查询执行全流程深度剖析
sql·mysql
輕華13 小时前
【零基础入门】SQL 核心语法精讲:外键约束与多表查询全解析(进阶篇)
数据库·sql
Yushan Bai14 小时前
ORACLE数据库无法查询到V$SESSION的BLOCKSESSION列问题的分析
数据库·oracle
white-persist15 小时前
【渗透测试 红队】Netcat(NC)渗透实战全指南详解
开发语言·数据库·python·sql·算法·web安全·网络安全
阿波罗尼亚16 小时前
函数、存储过程和聚集(聚合)函数
数据库·oracle