xml-parsing - Oracle:如何从表中的属性中提取 XML 数据
问题描述
我有一个带有 XmlType 属性的表,如下所示
<data>
<subdata name='FIRST'>AAA</subdata>
<subdata name='SECOND'>BBB</subdata>
<subdata name='THIRD'>CCC</subdata>
...
</data>
我想提取 XML 以获得以下结果:
----------------------------
| FIRST | SECOND | THIRD
|---------|---------|-------
| AAA | BBB | CCC
----------------------------
任何想法?我想补充一点,我知道结果表的结构,但每个元素都可以选择在 xml 中。
<data>
<subdata name='FIRST'>AAA</subdata>
<subdata name='SECOND'>BBB</subdata>
<subdata name='THIRD'>CCC</subdata>
...
</data>
<data>
<subdata name='SECOND'>EEE</subdata>
<subdata name='THIRD'>DDD</subdata>
...
</data>
| FIRST | SECOND | THIRD
|---------|---------|-------
| AAA | BBB | CCC
| | EEE | DDD
----------------------------
解决方案
你可以尝试这样做:
SELECT
ExtractValue(Value(p),'/data/subdata[@name="FIRST"]/text()') as name1
, ExtractValue(Value(p),'/data/subdata[@name="SECOND"]/text()') as name2
, ExtractValue(Value(p),'/data/subdata[@name="THIRD"]/text()') as name3
FROM TABLE(XMLSequence(Extract(xmltype('<doc><data><subdata name="FIRST">AAA</subdata><subdata name="SECOND">BBB</subdata><subdata name="THIRD">CCC</subdata></data><data><subdata name="SECOND">EEE</subdata><subdata name="THIRD">DDD</subdata></data></doc>')
,'/doc/data'))) p
推荐阅读
- android - 无需 FCM/GCM 的 Android 永久通知服务
- r - 二项式混合效应模型 BIC - R 与 SPSS
- python - 安装 statsmodels - Python 3.6 32 位
- php - Laravel 5.5.20:找不到命令
- javascript - 在ejs中获取“未定义窗口”
- hibernate - 在@Column 中区分 b/w @NotNull 注释和可为空
- shell - 无法在 Jenkins 管道中运行 shell 脚本
- vba - 即来自 VB 时序问题的自动化 (ReadyState)
- macos - Neo4j “数据库被杀” 试图在 macos 上安装 neosemantics 插件
- hyperledger - 单独组织和单独物理机中对等点的连接配置文件