【oracle】oracle数据处理将一行数据根据条件拆分为多行

前言

  有些情况下,我们需要把一行数据处理为多行,根据某个列的特性分隔符或者某种匹配条件进行数据清洗,类似这汇总情况我们可以通过oracle数据库的函数来进行处理转换,也是一种办法,下面演示如何使用sql将数据根据条件转换为多行。

一、实现效果

  根据爱好字段将有多个爱好的数据自动分为多行

原始数据表:

  表(PEOPLE)录入以下数据

目标效果:

二、实现方式

  利用oracle的JSON_TABLE函数, JSON_TABLE是 Oracle 12c 引入的函数,用于将 JSON 数据转换为关系型表格格式,使 JSON 数据可以像普通表一样进行查询和操作。

sql 复制代码
JSON_TABLE(
    json_document,
    json_path COLUMNS (column_definition)
) AS alias

参数说明:

json_document: 要处理的 JSON 数据源

json_path: JSON 路径表达式,指定要提取的数据

COLUMNS: 定义输出列的结构和数据类型

实现sql语句:

sql 复制代码
 select a.NAME,b.value  as HOBBY from PEOPLE a, JSON_TABLE('["' || REPLACE(a.HOBBY, '、','","')||'"]','$[*]' COLUMNS(value VARCHAR2(100) PATH '$'))b; 

解释:

  实际上上述sql是把要处理的字符串转换为了json再使用JSON_TABLE进行查询,其中代表遍历JSON数组中的所有元素,\*代表遍历 JSON 数组中的所有元素,代表遍历JSON数组中的所有元素,代表当前处理的 JSON 元素本身,通过JSON_TABLE转换后,将会把json数组中的每一个数据转换为行,也就实现了根据列条件分割转换为行的需求

解最终sql执行结果:

为了帮助更多像你一样的读者,我将持续在专栏中分享技术干货和实用技巧。如果你觉得这篇文章对你有帮助,可以考虑关注我的专栏,谢谢。

相关推荐
涛思数据(TDengine)3 分钟前
时序数据库 TDengine 在能碳管理平台中的关键技术选型与落地实践
数据库·时序数据库·tdengine
啊山0223245 分钟前
MySQL redo禁用导致全备失败
数据库·mysql
李白客15 分钟前
分布式交易型数据库:数字时代交易系统的“定海神针“
数据库·分布式
曹牧18 分钟前
Oracle:CHR的典型用法
数据库·oracle
我是一颗柠檬26 分钟前
【Java项目技术亮点】全链路分层限流:从网关到数据库的多层防护体系
java·开发语言·数据库
xhtdj36 分钟前
技术采用曲线回望二十年
运维·数据库·人工智能·clickhouse·动态规划
wh_xia_jun1 小时前
单元测试 + Mockito 开发指南
oracle·单元测试·log4j
油炸自行车1 小时前
【bug】Qt 6 Q_NAMESPACE 跨 DLL 链接错误:LNK2019 无法解析 staticMetaObject
数据库·c++·qt·bug·link2019·q_namespace_exp·namespaceexport
Arvin.Angela1 小时前
MySQL安装及运行环境配置
数据库·mysql·adb
Dovis(誓平步青云)1 小时前
《QT学习第五篇:QSS美化界面与API绘图》
开发语言·数据库·qt·学习·时序数据库·开源智能体