xml - 如何让 PL/SQL 解析 Oracle 中的 XML 属性而不是 XML 元素?

标签 xml oracle parsing xpath plsql

请参阅下面的 PL/SQL 片段:

create table t23 (
    field01 number, 
    field02 number, 
    field03 char(1) 
);

示例代码段 #1

declare x varchar2(2000) := '
<ArrayOfRecords>
<Record>
<Field01>130</Field01> 
<Field02>1700</Field02> 
<Field03>C</Field03> 
</Record> 
<Record>
<Field01>131</Field01> 
<Field02>1701</Field02> 
<Field03>B</Field03> 
</Record>                         
</ArrayOfRecords>';

begin
    insert
    into    T23
    SELECT  *
    FROM    XMLTABLE('/ArrayOfRecords/Record'
                PASSING xmltype(x)
                    COLUMNS 
                    Field01 number PATH 'Field01',
                    Field02 number PATH 'Field02',
                    Field03 char(1) PATH 'Field03'
            );
end;

-- The records will be here - great!
select  * from T23;

示例代码段 #2

declare y varchar2(2000) := '
<ArrayOfRecords>
<Record Field01="130" Field02="1700" Field03="C" />
<Record Field01="131" Field02="1701" Field03="B" />
</ArrayOfRecords>';

begin
    insert
    into    T23
    SELECT  *
    FROM    XMLTABLE('/ArrayOfRecords/Record'
                PASSING xmltype(y)
                    COLUMNS 
                    Field01 number PATH 'Field01',
                    Field02 number PATH 'Field02',
                    Field03 char(1) PATH 'Field03'
            );
end;

-- null values are inserted into the table - not great
select  * from T23;

如何从示例片段 #2 中的 XML 属性中获取值?有没有办法告诉 xmltype 从属性和元素中检索数据?

最佳答案

对属性使用@语法

select *
  from xmltable('/ArrayOfRecords/Record'
         passing xmltype(y)
         columns
         field01 number path '@Field01',
         field02 number path '@Field02',
         field03 char(1) path '@Field03'
       );

关于xml - 如何让 PL/SQL 解析 Oracle 中的 XML 属性而不是 XML 元素?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2222942/

相关文章:

python - 将复杂的 XML 文件转换为 Pandas dataframe/CSV - Python

sql - Oracle SQL 语句中多列的总和(按唯一 ID)

swift - 将 PFObject 指针转换为解析中的子类(swift)

c# - 如何将 JavaScript 多维数组解析为 C# 数组?

xml - 如何用 XPath 返回数组?

android - AlignParentBottom 按钮与 Scroll/Focus 上的 Textview 重叠

android - 折叠工具栏布局 |滚动和布局问题 2

java - 为什么 Hibernate 转而使用 LONG 而不是 CLOB?

javascript - 为什么我通过 AJAX 传递到 MVC Controller 的 XML 无法到达那里?

mysql - MySQL中如何选择记录类型