oracle kv字符串转换为多行两列

在Oracle数据库中,如果需要将一个包含多个值的KV(Key-Value)字符串转换为多行两列的格式,你可以使用多种方法来实现这个需求。这里将提供两种常见的方法:使用CONNECT BY语法和CASE表达式结合REGEXP_SUBSTR函数。

方法1:使用CONNECT BY

如果你KV字符串格式是类似于key1:value1,key2:value2,key3:value3这样的,你可以使用CONNECT BY和SYS_CONNECT_BY_PATH来实现:

WITH kv_data AS (

SELECT 'key1:value1,key2:value2,key3:value3' AS kv_string FROM dual

)

SELECT TRIM(SUBSTR(keys, 1, INSTR(keys, ':') - 1)) AS key,

TRIM(SUBSTR(keys, INSTR(keys, ':') + 1)) AS value

FROM (

SELECT TRIM(SYS_CONNECT_BY_PATH(SUBSTR(kv_string, INSTR(kv_string, ',', 1, level - 1) + 1,

INSTR(kv_string, ',', 1, level) - INSTR(kv_string, ',', 1, level - 1) - 1), ',') || ',') AS keys

FROM kv_data

CONNECT BY INSTR(kv_string, ',', 1, level) > 0

)

WHERE keys IS NOT NULL;

方法2:使用REGEXP_SUBSTR和CASE表达式

这种方法更适合于处理更复杂的情况或者当你想要更灵活地处理键值对时:

WITH kv_data AS (

SELECT 'key1:value1,key2:value2,key3:value3' AS kv_string FROM dual

)

SELECT REGEXP_SUBSTR(kv_string, '[^,]+', 1, level) AS key_val

FROM kv_data

CONNECT BY REGEXP_SUBSTR(kv_string, '[^,]+', 1, level) IS NOT NULL

AND PRIOR kv_string = kv_string

AND PRIOR sys_guid() IS NOT NULL;

然后,可以使用一个外部查询来将这个结果分解为键和值:

WITH kv_data AS (

SELECT 'key1:value1,key2:value2,key3:value3' AS kv_string FROM dual

), key_val AS (

SELECT REGEXP_SUBSTR(kv_string, '[^,]+', 1, level) AS key_val

FROM kv_data

CONNECT BY REGEXP_SUBSTR(kv_string, '[^,]+', 1, level) IS NOT NULL

AND PRIOR kv_string = kv_string

AND PRIOR sys_guid() IS NOT NULL

)

SELECT SUBSTR(key_val, 1, INSTR(key_val, ':') - 1) AS key,

SUBSTR(key_val, INSTR(key_val, ':') + 1) AS value

FROM key_val;

相关推荐
CV艺术家2 小时前
java原mysql切换国产达梦数据库
数据库·mysql
好大哥呀2 小时前
如何在Spring Boot中配置数据库连接?
数据库·spring boot·后端
xcLeigh2 小时前
IoTDB数据订阅API实战:实时消费数据+TsFile订阅全攻略
数据库·api·iotdb·数据备份·tsfile·数据订阅
许杰小刀2 小时前
使用 Python 将 Excel 数据批量导入到数据库中(SQLite)
数据库·python·excel
一个天蝎座 白勺 程序猿2 小时前
Apache IoTDB(16):时序数据库的数据删除从单点精准清除到企业级数据生命周期管理
数据库·apache·时序数据库·iotdb
努力进修2 小时前
【MySQL】90% 的 MySQL 性能问题都和它有关!索引的正确打开方式,看完少走 3 年弯路
数据库·mysql
架构师老Y2 小时前
005、数据库选型与ORM技术:SQLAlchemy深度解析
数据库·python
清水白石0082 小时前
Python 在数据栈中的边界:何时高效原型、何时切换到 SQL、Spark、Rust 或数据库原生能力
数据库·python·自动化
dishugj2 小时前
sqlplus / as sysdba登录数据库报错ora-01017解决办法
数据库·oracle