首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在postgresql中获取XML值

在postgresql中获取XML值
EN

Stack Overflow用户
提问于 2014-06-05 09:47:38
回答 2查看 1.4K关注 0票数 0

在postgres数据库(jira中的工作流)表中的一列中有以下xml:

代码语言:javascript
复制
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE workflow PUBLIC "-//OpenSymphony Group//DTD OSWorkflow 2.8//EN" "http://www.opensymphony.com/osworkflow/workflow_2_8.dtd">
<workflow>
    ...
  <steps>
    <step id="1" name="New">
        ...
    </step>
    <step id="5" name="Resolved">
        ...
    </step>
    <step id="10" name="Closed">
        ...
    </step>
  </steps>
  ...
</workflow>

我想选择映射:

代码语言:javascript
复制
1 - New
5 - Resolved
10 - Closed

怎样才能做到这一点?我应该使用哪个postgres函数?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-06-05 10:48:14

您将需要使用xpath 函数

代码语言:javascript
复制
select
  unnest(xpath('//workflow/steps/step/@id', xmlin)),
  unnest(xpath('//workflow/steps/step/@name', xmlin))
from
  (select xmlparse(document '<?xml version="1.0"?>
  <!DOCTYPE workflow PUBLIC "-//OpenSymphony Group//DTD OSWorkflow 2.8//EN" "http://www.opensymphony.com/osworkflow/workflow_2_8.dtd">
<workflow>
  <steps>
    <step id="1" name="New">
    </step>
    <step id="5" name="Resolved">
    </step>
    <step id="10" name="Closed">
    </step>
  </steps>
</workflow>') xmlin) x

----
1;New
5;Resolved
10;Closed

注意--正如@posz所指出的,如果缺少nameid属性,这是行不通的。

票数 0
EN

Stack Overflow用户

发布于 2014-06-05 10:51:19

要处理xml节点,可以使用xpath()函数:

代码语言:javascript
复制
with v(x) as (
  select xmlparse(document '<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE workflow PUBLIC "-//OpenSymphony Group//DTD OSWorkflow 2.8//EN" "http://www.opensymphony.com/osworkflow/workflow_2_8.dtd">
<workflow><steps><step id="1" name="New"/><step id="5" name="Resolved"/><step id="10" name="Closed"/></steps></workflow>')
)
select (xpath('@id', step))[1] as id, (xpath('@name', step))[1] as name
from v
cross join lateral unnest(xpath('/workflow/steps/step', x)) as step

结果列将按类型xml排列,因此可能需要进行转换。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24056893

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档