Oracle JSON 函数详解与实战
Oracle 数据库提供了丰富的 JSON 函数集,使得开发者可以高效地处理 JSON 数据。本文将详细介绍这些函数,包括它们的语法、使用场景、具体示例,以及在实际项目中的应用。
文章目录
JSON_VALUE
JSON_VALUE 函数用于从 JSON 文档中提取单个标量值(如字符串、数字、布尔值)。它特别适合用于提取具体的字段值。
语法
JSON_VALUE(expression, path RETURNING data_type DEFAULT default_value ON ERROR error_clause)
参数说明
expression: JSON 数据的列或文本。path: JSON 路径表达式,指向要提取的值。data_type: 返回的数据类型。default_value: 如果未找到值时的默认值。error_clause: 发生错误时的处理方式。
示例
从 JSON 文档中提取名称为 “name” 的值,并指定返回类型为 VARCHAR2:
SELECT JSON_VALUE('{"name": "John", "age": 30}', '$.name' RETURNING VARCHAR2) AS name
FROM dual;
JSON_QUERY
JSON_QUERY 函数用于从 JSON 文档中提取 JSON 对象或数组,而不是单个标量值。
语法
JSON_QUERY(expression, path [ RETURNING data_type ] [ PRETTY ] [ WITH UNIQUE KEYS ] [ error_clause ])
示例
从 JSON 文档中提取地址对象:
SELECT JSON_QUERY('{"name": "John", "age": 30, "address": {"city": "New York", "zipcode": "10001"}}', '$.address') AS address
FROM dual;
JSON_TABLE
JSON_TABLE 函数将 JSON 数据展开为关系表形式,允许你使用 SQL 查询 JSON 数据的各个部分。
语法
JSON_TABLE(expression, pathCOLUMNS (column_name column_type PATH 'json_path' [ DEFAULT default_expr ] [ error_clause ] ...)
)
示例
将 JSON 数组展开为表格:
SELECT jt.title, jt.key, jt.level
FROM json_table,JSON_TABLE(json_column, '$[*]'COLUMNS (title VARCHAR2(100) PATH '$.title',key VARCHAR2(50) PATH '$.key',level NUMBER PATH '$.level')) jt;
JSON_EXISTS
JSON_EXISTS 函数用于检查 JSON 文档中是否存在指定的路径。
语法
JSON_EXISTS(expression, path [ error_clause ])
示例
检查 JSON 文档中是否存在 “address” 对象:
SELECT JSON_EXISTS('{"name": "John", "age": 30, "address": {"city": "New York", "zipcode": "10001"}}', '$.address') AS address_exists
FROM dual;
JSON_OBJECT
JSON_OBJECT 函数用于生成一个 JSON 对象,它允许将键值对转换为 JSON 格式。
语法
JSON_OBJECT(key VALUE value [, key VALUE value ] ...)
示例
生成一个 JSON 对象:
SELECT JSON_OBJECT('name' VALUE 'John', 'age' VALUE 30) AS json_object
FROM dual;
JSON_ARRAY
JSON_ARRAY 函数用于生成一个 JSON 数组,支持多种类型的值。
语法
JSON_ARRAY(value [, value ] ...)
示例
生成一个 JSON 数组:
SELECT JSON_ARRAY('apple', 'banana', 42) AS json_array
FROM dual;
JSON_MERGEPATCH
JSON_MERGEPATCH 函数用于将两个 JSON 文档合并。它遵循 JSON Merge Patch 标准,适合用于部分更新 JSON 文档。
语法
JSON_MERGEPATCH(target, patch)
示例
将两个 JSON 文档合并:
SELECT JSON_MERGEPATCH('{"name": "John", "age": 30}', '{"age": 31, "city": "New York"}') AS merged_json
FROM dual;
JSON_OBJECTAGG
JSON_OBJECTAGG 函数用于将一组键值对聚合成一个 JSON 对象,通常用于 GROUP BY 查询中。
语法
JSON_OBJECTAGG(key, value)
示例
将一组键值对聚合成 JSON 对象:
SELECT JSON_OBJECTAGG(department_name, department_id) AS departments_json
FROM departments
GROUP BY some_column;
JSON_ARRAYAGG
JSON_ARRAYAGG 函数用于将一组值聚合成一个 JSON 数组,类似于 SQL 的 ARRAY_AGG 函数。
语法
JSON_ARRAYAGG(value)
示例
将一组值聚合成 JSON 数组:
SELECT JSON_ARRAYAGG(employee_name) AS employees_json
FROM employees
GROUP BY some_column;
JSON_SCALAR
JSON_SCALAR 函数将标量值转换为 JSON 标量值,适合用于需要将 SQL 标量值转换为 JSON 格式的场景。
语法
JSON_SCALAR(value)
示例
将字符串转换为 JSON 标量值:
SELECT JSON_SCALAR('Hello, World!') AS json_scalar
FROM dual;
JSON_DATAGUIDE
JSON_DATAGUIDE 函数用于生成 JSON 数据指南,描述 JSON 文档的结构。它对于了解和管理复杂的 JSON 数据非常有用。
语法
JSON_DATAGUIDE(expression)
示例
生成 JSON 数据指南:
SELECT JSON_DATAGUIDE('{"name": "John", "age": 30, "address": {"city": "New York", "zipcode": "10001"}}') AS data_guide
FROM dual;
实战应用场景
场景一:从复杂 JSON 结构中提取多层嵌套数据
假设我们有一个复杂的 JSON 结构,包含嵌套的对象和数组。我们需要从中提取某些特定的信息并进行统计分析。
示例数据
{"employees": [{"name": "Alice","age": 30,"department": {"name": "Sales","location": "New York"},"projects": [{"name": "Project A", "status": "Completed"},{"name": "Project B", "status": "Ongoing"}]},{"name": "Bob","age": 35,"department": {"name": "HR","location": "Chicago"},"projects": [{"name": "Project C", "status": "Ongoing"}]}]
}
查询示例
SELECT e.name, e.age, d.name AS department_name, d.location, p.name AS project_name, p.status
FROM json_table t,JSON_TABLE(t.json_column, '$.employees[*]'COLUMNS (name VARCHAR2(50) PATH '$.name',age NUMBER PATH '$.age',NESTED PATH '$.department' COLUMNS (department_name VARCHAR2(50) PATH '$.name',location VARCHAR2(50) PATH '$.location'),NESTED PATH '$.projects[*]' COLUMNS (project_name VARCHAR2(50) PATH '$.name',status VARCHAR2(20) PATH '$.status'))) e;
场景二:合并和更新 JSON 文档
假设我们有两个 JSON 文档,表示不同时间点的用户信息更新。我们需要合并这些文档以生成最新的用户信息。
示例数据
{"name": "John","age": 30,"address": {"city": "New York", "zipcode": "10001"}
}
{"age": 31,"address": {"city": "San Francisco"}
}
合并示例
SELECT JSON_MERGEPATCH('{"name": "John", "age": 30, "address": {"city": "New York", "zipcode": "10001"}}','{"age": 31, "address": {"city": "San Francisco"}}') AS merged_json
FROM dual;
结论
Oracle 提供了全面的 JSON 函数集,允许开发者高效地处理 JSON 数据。无论是提取、查询、生成还是合并 JSON 数据,这些函数都能满足各种实际需求。通过掌握这些函数,开发者可以更好地在 Oracle 数据库中处理和分析 JSON 数据。希望本文能帮助你更好地理解和应用这些强大的工具。
相关文章:
Oracle JSON 函数详解与实战
Oracle 数据库提供了丰富的 JSON 函数集,使得开发者可以高效地处理 JSON 数据。本文将详细介绍这些函数,包括它们的语法、使用场景、具体示例,以及在实际项目中的应用。 文章目录 JSON_VALUE语法参数说明示例 JSON_QUERY语法示例 JSON_TABLE语…...
C#面:请解释转发与跳转的区别
在C#中,转发(forwarding)和跳转(jumping)是两种不同的控制流程操作。 转发 是指将控制权从一个方法或函数转移到另一个方法或函数。在转发中,程序会将当前的执行状态传递给另一个方法,并在该方…...
Java+IDEA+SpringBoot药物不良反应ADR智能监测系统源码 ADR智能化监测系统源码
JavaIDEASpringBoot药物不良反应ADR智能监测系统源码 ADR智能化监测系统源码 药物不良反应(Adverse Drug Reaction,ADR)是指在使用合格药品时,在正常的用法和用量下出现的与用药目的无关的有害反应。这些反应往往因药物种类、使用…...
linux系统模拟资源消耗的简单手段
当我们在做系统性能,稳定性,高可用等特殊场景的测试时,往往要对计算机的硬件资源做出比较苛刻的限制,因此需要最简便的办法增加CPU,内存,磁盘,网络等硬件环境的资源压力。下面介绍实现这些操作的…...
吉林大学软件工程简答题整理
1.6种软件过程模型列举,及优缺点(每个都从时间、质量、过程、本身特点去考虑) 瀑布模型 优点缺点V模型 优点:缺点: 原型模型 优点:演化模型 建增模型 优点缺点螺旋模型 优点缺点喷泉模型 RUP、敏捷工程、…...
爬山算法介绍
目录 1.概述 2.产生 3.定义 4.优缺点 5.应用示例 6.未来展望 7.示例代码 1.概述 爬山算法是一种简单的启发式搜索算法,从起始点开始,每次选择当前位置邻域内的最优解作为下一个位置,直到达到目标点或无法继续前进。爬山算法的基本思想…...
在linux中配置关于GFS创建各种卷以及卷组--配置实验
服务器的相关信息 服务器的相关信息 卷名称 卷类型 空间大小 Brick dis-volume 分布式卷 12 Node1(/e6)、node2(/e6) Stripe-volume 条带卷 10 Node1(/d5)、node2(/d5) Rep-volume 复制卷 5 Node3(/d5)、node4(/d5) Dis-stripe 分布式条带卷 12 Node1(/b3)、node2(/b3)、node(…...
安泰电子:使用高压放大器时有哪些需要注意的呢
随着科技的不断进步,高压放大器在各种科学实验、工程应用和产业生产中扮演着重要的角色。然而,由于高压放大器的特殊性,使用时需要特别小心和谨慎。下面将详细介绍使用高压放大器时需要注意的事项,以确保安全、稳定地进行实验和应…...
为什么大部分新手做抖音小店赚不到钱?
大家好,我是喷火龙。 今天来给大家聊聊,为什么大部分新手做抖店赚不到钱? 不知道大家想过这个问题没有,可能有些人把赚不到钱的原因归结于市场、或者平台、又或者运营技术以及做店经验。 但我觉得这些都不是重点,重…...
跳跃游戏(2)
问题描述 给你一个非负整数数组 nums ,你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。 判断你是否能够到达最后一个下标,如果可以,返回 true ;否则,返回 false 。 输入࿱…...
11.Redis之zset类型
1.zset类型基本介绍 有序描述的是:升序/降序 Set 集合 1.唯一 2. 无序 孙行者,行者孙, 者行孙 >同一只猴~~ List有序的 孙行者,行者孙, 者行孙 >不同的猴~~ zset 中的 member 仍然要求是唯一的!!(score 则可以重复) 排序的规则是啥? 给 zset 中的 member 同…...
Python怎样将PDF拆分成多个文件
在 Python 中,你可以使用 PyPDF2 库来拆分 PDF 文件。以下是一个简单的示例,演示如何将一个 PDF 文件拆分为多个单页 PDF 文件。 首先,你需要安装 PyPDF2 库。如果尚未安装,可以使用以下命令进行安装: pip install P…...
C语言-----前置++和后置++的不同
#include <stdio.h> int main() {int a, b, c;a 5;c a;b c, c, a, a;b a c;printf("a %d b %d c %d\n:", a, b, c);return 0; }/*1、逗号运算符的优先级比赋值运算符号的优先级低2、、的优先级比高3、多个号在一起的时候,其优先级为后置、、…...
685. 冗余连接 II
685. 冗余连接 II 问题描述 在本问题中,有根树指满足以下条件的 有向 图。该树只有一个根节点,所有其他节点都是该根节点的后继。该树除了根节点之外的每一个节点都有且只有一个父节点,而根节点没有父节点。 输入一个有向图,该…...
自养号测评是什么?亚马逊、沃尔玛、Target卖家如何建立自己的护城河?
近期有跨境卖家咨询我自养买家账号测评的事情,他们还是有不了解自养号测评的,所以珑哥觉得有必要再讲一下卖家测评的一些事情,之前文章也说过。这可能是跨境卖家运营的一个趋势。今天珑哥着重来介绍一下自养号测评 一、什么叫做自养号测评&a…...
计算机毕业设计 | SpringBoot招投标 任务发布网站(附源码)
1,绪论 在市场范围内,任务发布网站很受欢迎,有很多开发者以及其他领域的牛人,更倾向于选择工作时间、工作场景更自由的零工市场寻求零散单子来补贴家用。 如今市场上,任务发布网站鱼龙混杂,用户需要找一个…...
element el-table表格表头某一列表头文字或者背景修改颜色
效果如下 整体代码 ,具体方法在最下面! <el-table v-loading"listLoading" :data"sendReceivList" element-loading-text"Loading" border fit ref"tableList" :header-cell-class-name"addClass&quo…...
移动云:连接未来的智慧之旅
随着数字化转型的加速,云服务在各行各业中的应用越来越广泛。移动云不仅提供了灵活的计算和存储资源,还通过创新的技术手段,为企业和开发者解决了许多实际问题。在这个变革的大背景下,移动云服务作为中国移动倾力打造的云业务品牌…...
如何确保大模型 RAG 生成的信息是基于可靠的数据源?
在不断发展的人工智能 (AI) 领域中,检索增强生成 (RAG) 已成为一种强大的技术。 RAG 弥合了大型语言模型 (LLM) 与外部知识源之间的差距,使 AI 系统能够提供更全面和信息丰富的响应。然而,一个关键因素有时会缺失——透明性。 我们如何能够…...
Laravel(Lumen8) + Supervisor 实现多进程redis消息队列
相关文章:Supervisor守护进程工具安装与使用 1、通用消息队列 /App/Job/CommonJob.php: <?phpnamespace App\Jobs; use Illuminate\Support\Facades\Log; use Illuminate\Support\Str;class CommonJob extends Job {public $timeout; //超时时间protected $data; //队列…...
Android Wi-Fi 连接失败日志分析
1. Android wifi 关键日志总结 (1) Wi-Fi 断开 (CTRL-EVENT-DISCONNECTED reason3) 日志相关部分: 06-05 10:48:40.987 943 943 I wpa_supplicant: wlan0: CTRL-EVENT-DISCONNECTED bssid44:9b:c1:57:a8:90 reason3 locally_generated1解析: CTR…...
大话软工笔记—需求分析概述
需求分析,就是要对需求调研收集到的资料信息逐个地进行拆分、研究,从大量的不确定“需求”中确定出哪些需求最终要转换为确定的“功能需求”。 需求分析的作用非常重要,后续设计的依据主要来自于需求分析的成果,包括: 项目的目的…...
django filter 统计数量 按属性去重
在Django中,如果你想要根据某个属性对查询集进行去重并统计数量,你可以使用values()方法配合annotate()方法来实现。这里有两种常见的方法来完成这个需求: 方法1:使用annotate()和Count 假设你有一个模型Item,并且你想…...
Keil 中设置 STM32 Flash 和 RAM 地址详解
文章目录 Keil 中设置 STM32 Flash 和 RAM 地址详解一、Flash 和 RAM 配置界面(Target 选项卡)1. IROM1(用于配置 Flash)2. IRAM1(用于配置 RAM)二、链接器设置界面(Linker 选项卡)1. 勾选“Use Memory Layout from Target Dialog”2. 查看链接器参数(如果没有勾选上面…...
Mobile ALOHA全身模仿学习
一、题目 Mobile ALOHA:通过低成本全身远程操作学习双手移动操作 传统模仿学习(Imitation Learning)缺点:聚焦与桌面操作,缺乏通用任务所需的移动性和灵活性 本论文优点:(1)在ALOHA…...
【Go语言基础【13】】函数、闭包、方法
文章目录 零、概述一、函数基础1、函数基础概念2、参数传递机制3、返回值特性3.1. 多返回值3.2. 命名返回值3.3. 错误处理 二、函数类型与高阶函数1. 函数类型定义2. 高阶函数(函数作为参数、返回值) 三、匿名函数与闭包1. 匿名函数(Lambda函…...
嵌入式学习笔记DAY33(网络编程——TCP)
一、网络架构 C/S (client/server 客户端/服务器):由客户端和服务器端两个部分组成。客户端通常是用户使用的应用程序,负责提供用户界面和交互逻辑 ,接收用户输入,向服务器发送请求,并展示服务…...
Golang——7、包与接口详解
包与接口详解 1、Golang包详解1.1、Golang中包的定义和介绍1.2、Golang包管理工具go mod1.3、Golang中自定义包1.4、Golang中使用第三包1.5、init函数 2、接口详解2.1、接口的定义2.2、空接口2.3、类型断言2.4、结构体值接收者和指针接收者实现接口的区别2.5、一个结构体实现多…...
uniapp 小程序 学习(一)
利用Hbuilder 创建项目 运行到内置浏览器看效果 下载微信小程序 安装到Hbuilder 下载地址 :开发者工具默认安装 设置服务端口号 在Hbuilder中设置微信小程序 配置 找到运行设置,将微信开发者工具放入到Hbuilder中, 打开后出现 如下 bug 解…...
API网关Kong的鉴权与限流:高并发场景下的核心实践
🔥「炎码工坊」技术弹药已装填! 点击关注 → 解锁工业级干货【工具实测|项目避坑|源码燃烧指南】 引言 在微服务架构中,API网关承担着流量调度、安全防护和协议转换的核心职责。作为云原生时代的代表性网关,Kong凭借其插件化架构…...
