如何将嵌套的 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/