我可以在没有ORM的情况下将XML导入Postgres数据库吗?

时间:2012-05-21 18:53:38

标签: java xml postgresql jdbc xml-parsing

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

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

1 个答案:

答案 0 :(得分:4)

创建一个“staging”表,其中包含要导入的每个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链接。

相关问题