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

相关推荐
美味的大香蕉6 小时前
Spark SQL
笔记
轻闲一号机7 小时前
【机器学习】机器学习笔记
人工智能·笔记·机器学习
天下琴川8 小时前
Dify智能体平台源码二次开发笔记(5) - 多租户的SAAS版实现(2)
人工智能·笔记
workworkwork勤劳又勇敢10 小时前
Adversarial Attack对抗攻击--李宏毅机器学习笔记
人工智能·笔记·深度学习·机器学习
执键行天涯10 小时前
在vue项目中package.json中的scripts 中 dev:“xxx“中的xxx什么概念
前端·vue.js·json
寻丶幽风11 小时前
论文阅读笔记——Generating Long Sequences with Sparse Transformers
论文阅读·笔记·语言模型·transformer·稀疏自注意力
Angindem11 小时前
websoket 学习笔记
笔记·学习
Arbori_2621513 小时前
Oracle WITH 子句(也称为 公共表表达式,Common Table Expression,CTE)
数据库·oracle
x-cmd14 小时前
x-cmd install | jellex - 用 Python 语法在终端里玩转 JSON 数据!
开发语言·python·json·命令行终端
Bartender_Jill15 小时前
【Claude AI大语言模型连接Blender生成资产】Windows安装Blender MCP教程
人工智能·语言模型·json·游戏引擎·blender