oracle json笔记

文章目录

有些数据是以json格式存储,常规的sql语句操作起来不太方便,别担心,数据库早就有对应的函数了。

json_value

适用于从json中提取单个值。

语法:

json 复制代码
JSON_VALUE(expression, path RETURNING data_type DEFAULT default_value ON ERROR error_clause)

.(点号)表示上下级关系。

属性的表示方法: $.一级属性.二级属性.三级属性...

数组的表示方法: $.columns[0].title

json_value示例
sql 复制代码
SELECT 
json_value(字段名, '$.user.name' RETURNING VARCHAR2) AS name
FROM 表名 t;
json_value on error如何使用 TODO

这个好像和pl/sql编程有关,直接写在语句里面好像不成立,有时间研究下。

json_query

适用于从json中提取对象或数组,如果是个值,反而会返回空。

语法:

json 复制代码
JSON_QUERY(expression, path [ RETURNING data_type ] [ PRETTY ] [ WITH UNIQUE KEYS ] [ error_clause ])
json_query示例

示例:

sql 复制代码
SELECT json_query(字段名,'$.user') FROM 表名

json_table

将json数据展开为关系表形式,允许使用sql查询json的各个部分。

语法:

json 复制代码
JSON_TABLE(expression, path
  COLUMNS (column_name column_type PATH 'json_path' [ DEFAULT default_expr ] [ error_clause ] ...)
)
json_table 示例
c 复制代码
SELECT jt.* FROM 表名, 
json_table(
字段名,'$.*'
columns(
	title VARCHAR2(100) PATH '$.*'
	
)
) jt

说实话,没太看懂怎么用,拿的数据也感觉不对。

对数据有什么要求呢? 是以数组的形式还是对象的形式呢? 有时间看下。TODO

json_exists

json_exists示例

正确示例:

sql 复制代码
 SELECT *
 FROM 表名
 WHERE JSON_EXISTS(字段名, '$.aaa'); 

注:json_exists()一般用于判断条件中,如果用在select的列中,会报错,[ORA-40458: 在谓词外部使用了 JSON_EXISTS]。

json_exists报错 ORA-40458: 在谓词外部使用了 JSON_EXISTS

错误示例:

sql 复制代码
SELECT JSON_EXISTS('{"name": "John", "age": 30, "address": {"city": "New York", "zipcode": "10001"}}', '$.address') AS address_exists
FROM dual;

这条语句从网上找的,实测报错,所以实践出真知是很有道理的。

json_object

json_array

json_mergepatch

json_objectagg

json_arrayagg

json_scalar

json_dataguide

其他

不错的文章

https://blog.csdn.net/mbh12333/article/details/139126090

相关推荐
Keep Running *20 小时前
Spring Cloud Alibaba_学习笔记
笔记·学习
jnrjian20 小时前
text index 查看index column index定义 index 刷新频率 index视图
数据库·oracle
韶博雅21 小时前
emcc升级
oracle
我不是懒洋洋21 小时前
AI的影响6
笔记
迷枫7121 天前
达梦数据库的体系架构
数据库·oracle·架构
夜晚打字声1 天前
9(九)Jmeter如何连接数据库
数据库·jmeter·oracle
NineData1 天前
NineData 智能数据管理平台新功能发布|2026 年 3 月
数据库·oracle·架构·dba·ninedata·数据复制·数据迁移工具
咖啡忍者1 天前
【SAP CO】4.COPC产品成本控制-3.WIP后台配置
笔记
不愿透露姓名的大鹏1 天前
Oracle归档日志爆满急救指南
linux·数据库·oracle·dba
CheerWWW1 天前
深入理解计算机系统——位运算、树状数组
笔记·学习·算法·计算机系统