如何从postgres中的xml列中选择具有属性的数据

时间:2016-06-21 05:56:03

标签: xml postgresql

我有以下xml内容:

<?xml version="1.0" encoding="utf-8"?>
<h:html xmlns="http://www.w3.org/2002/xforms" xmlns:ev="http://www.w3.org/2001/xml-events" xmlns:h="http://www.w3.org/1999/xhtml" xmlns:jr="http://openrosa.org/javarosa" xmlns:orx="http://openrosa.org/xforms" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
  <h:head>
    <h:title>Demo12</h:title>
    <model>
      <instance>
        <uploaded_form_bpdwls id="Demo12">
          <formhub>
            <uuid/>
          </formhub>
          <Household_Number/>
          <Survey_Name/>
          <start/>
          <end/>
          <meta>
            <instanceID/>
          </meta>
        </uploaded_form_bpdwls>
      </instance>
    </model>
  </h:head>
  <h:body>
    <input ref="/uploaded_form_bpdwls/Household_Number">
      <label>Household Number</label>
    </input>
    <input ref="/uploaded_form_bpdwls/Survey_Name">
      <label>Survey Name</label>
    </input>
  </h:body>
</h:html>

在上面的XML内容中,

  • 在体内,有两个具有不同属性的输入标签(即@ref =“/ uploaded_form_bpdwls / Household_Number)。

  • 我试图通过postgresSQL以表格格式选择数据。我希望“House Hold”和“Survey Name”作为单独的列。

  • 我不知道如何使用标签属性选择数据。

是否可以在单独的列中选择数据

实现这一目标的选择查询应该是什么?

1 个答案:

答案 0 :(得分:1)

这是你想要的吗? :

with table1 as (
  select $$<?xml version="1.0" encoding="utf-8"?>
 <h:html xmlns="http://www.w3.org/2002/xforms" xmlns:ev="http://www.w3.org/2001/xml-events" xmlns:h="http://www.w3.org/1999/xhtml" xmlns:jr="http://openrosa.org/javarosa" xmlns:orx="http://openrosa.org/xforms" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<h:head>
<h:title>Demo12</h:title>
<model>
  <instance>
    <uploaded_form_bpdwls id="Demo12">
      <formhub>
        <uuid/>
      </formhub>
      <Household_Number/>
      <Survey_Name/>
      <start/>
      <end/>
      <meta>
        <instanceID/>
      </meta>
    </uploaded_form_bpdwls>
  </instance>
</model>
</h:head>
<h:body>
<input ref="/uploaded_form_bpdwls/Household_Number">
  <label>Household Number</label>
</input>
<input ref="/uploaded_form_bpdwls/Survey_Name">
  <label>Survey Name</label>
</input>
 </h:body>
 </h:html>$$::xml as xml_content

 )

 select myarray[1] val1,myarray[2] val2 from (
    select xpath('/h:html/h:body/i:input/i:label/text()',xml_content,ARRAY[ARRAY['h','http://www.w3.org/1999/xhtml'],ARRAY['i','http://www.w3.org/2002/xforms']]) myarray from table1  
 ) a

对于多级尝试:

        with table1 as (
        select $$<?xml version="1.0" encoding="utf-8"?>
        <h:html xmlns="http://www.w3.org/2002/xforms" xmlns:ev="http://www.w3.org/2001/xml-events" xmlns:h="http://www.w3.org/1999/xhtml" xmlns:jr="http://openrosa.org/javarosa" xmlns:orx="http://openrosa.org/xforms" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
          <h:head>
            <h:title>Demo12</h:title>
            <model>
              <instance>
                <uploaded_form_bpdwls id="Demo12">
                  <formhub>
                    <uuid/>
                  </formhub>
                  <Household_Number/>
                  <Survey_Name/>
                  <start/>
                  <end/>
                  <meta>
                    <instanceID/>
                  </meta>
                </uploaded_form_bpdwls>
              </instance>
            </model>
          </h:head>
          <h:body>
            <div>
            <input ref="/uploaded_form_bpdwls/Household_Number">
              <label>Household Number</label>
            </input>
            <input ref="/uploaded_form_bpdwls/Survey_Name">
              <label>Survey Name</label>
            </input>
            </div>
            <div>
            <input ref="/uploaded_form_bpdwls/Household_Number">
              <label>Household Number2</label>
            </input>
            <input ref="/uploaded_form_bpdwls/Survey_Name">
              <label>Survey Name2</label>
            </input>
            </div>
          </h:body>
        </h:html>$$::xml as xml_content

        )

        select myarray[1] val1,myarray[2] val2 from (
           select xpath('/i:div/i:input/i:label/text()',xml_content,ARRAY[ARRAY['h','http://www.w3.org/1999/xhtml'],ARRAY['i','http://www.w3.org/2002/xforms']]) myarray from 
              (
              select unnest(xpath('/h:html/h:body/i:div',xml_content,ARRAY[ARRAY['h','http://www.w3.org/1999/xhtml'],ARRAY['i','http://www.w3.org/2002/xforms']])) xml_content from table1
              ) div
           ) a