我需要能够从/向PostgresQL数据库导出/导入XML数据。我查看了documentation,并确定我可以使用查询或表格轻松导出XML。将相同的XML重新导入同一个数据库的最简单方法是什么?我不喜欢使用第三方工具,但会处理PG函数和Java / JDBC中的任何编程。
我会投票给任何提供有用信息的人。
答案 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链接。