0

我需要能够从/向 PostgresQL 数据库导出/导入 XML 数据。我查看了文档,并确定我可以使用查询或表轻松导出 XML。将相同的 XML 重新导入同一个数据库的最简单方法是什么?我不喜欢使用第三方工具,但会处理 PG 函数和 Java/JDBC 中的任何编程。

我会投票给任何提供有用信息的人。

4

1 回答 1

4

创建一个“临时”表,其中包含您要导入的每个 XML 的一行。

然后使用 XML 函数(例如 xpath_table)将该 XML 列分割成行和列。像这样的东西:

-- make sure xpath_table is available
create extension xml2;

-- create XML staging table
create table xml_test (id integer, xml text);

-- create sample XML document
insert into xml_test  (id, data)
values
(1, '<person-list>
    <person>
        <id>42</id>
        <firstname>Arthur</firstname>
        <lastname>Dent</lastname>
    </person>
    <person>
        <id>43</id>
        <firstname>Zaphod</firstname>
        <lastname>Beeblebrox</lastname>
    </person>
</person-list>'
);

现在,如果您的目标表是例如:

create table person 
(
   id integer not null primary key,
   firstname text,
   lastname text
);

您可以使用:

insert into person (id, firstname, lastname)
select person_id, firstname, lastname
from xpath_table('id', 'xml', 'xml_test', 
                 '/person-list/person/id|/person-list/person/firstname|/person-list/person/lastname', 'id=1')
as t (docid integer, person_id integer, firstname text, lastname text)

该函数的最后一个参数id=1是从包含 XML 列的表中选择的行。如果那里有多个文档,则需要选择与 xpath 表达式匹配的文档

您还可以使用核心 XML 函数在没有 xml2 模块的情况下创建类似的视图。请参阅 user272735 在评论中发布的链接。

于 2012-05-21T19:40:40.663 回答