xml - 甲骨文PLSQL : how to parse XML and insert into table

标签 xml oracle plsql insert xml-parsing

如何将嵌套的 xml 文件加载到数据库表中?

<?xml version="1.0" ?> 
<person>
   <row>
       <name>Tom</name>
       <Address>
           <State>California</State>
           <City>Los angeles</City>
       </Address>
   </row>
   <row>
       <name>Jim</name>
       <Address>
           <State>California</State>
           <City>Los angeles</City>
       </Address>
   </row>
</person>       

在这个xml中,person是表名,name是字段名,Tom是它的字段值。 Address 是一个子表,state 和 city 是 Address 中的两列。我想将人员行插入到人员表中,如果失败,则不要插入到地址表中。这个 xml 可能非常大。执行此操作的最佳解决方案是什么?

最佳答案

您可以将 XML 文档加载到 XMLType 中,然后查询它,例如:

DECLARE
  x XMLType := XMLType(
    '<?xml version="1.0" ?> 
<person>
   <row>
       <name>Tom</name>
       <Address>
           <State>California</State>
           <City>Los angeles</City>
       </Address>
   </row>
   <row>
       <name>Jim</name>
       <Address>
           <State>California</State>
           <City>Los angeles</City>
       </Address>
   </row>
</person>');
BEGIN
  FOR r IN (
    SELECT ExtractValue(Value(p),'/row/name/text()') as name
          ,ExtractValue(Value(p),'/row/Address/State/text()') as state
          ,ExtractValue(Value(p),'/row/Address/City/text()') as city
    FROM   TABLE(XMLSequence(Extract(x,'/person/row'))) p
    ) LOOP
    -- do whatever you want with r.name, r.state, r.city
  END LOOP;
END;

关于xml - 甲骨文PLSQL : how to parse XML and insert into table,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12982687/

相关文章:

java - 如何在滚动 Activity 下放置广告 View 横幅?

java - Spring-MVC - 创建名称为 'procesarController' : Injection of autowired dependencies failed 的 bean 时出错

oracle - 如何在 Oracle SQL*Plus 中显示 LOB 列的完整内容?

database - 与用于 OLTP 的 Oracle 和 DB2 相比,PostgreSQL 缺少的最关键的特性是什么?

html - 如何在不知道编码的情况下读取编码头?

android - 如何添加广播组

oracle - 你能动态获取你在oracle apex中所在的页码吗?

sql - ORA-01403 - 未找到数据 - 即使游标 SELECT 语句运行正常

java - 在prepareCall后遇到符号\"CLOSE\"

sql - ORACLE - 如何创建将在 NLS_COMP=Linguistic 和 NLS_Sort=Binary_CI 时使用的索引