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