3

我有两个 XML 文件,想加入它们以获得所需的输出。

XML 文件 -1

<Countries>
<Country>
   <No C="1"/>
   <Name>India</Name>
</Country>
<Country>
   <No C="2"/>
   <Name>USA</Name>
</Country>
<Country>
   <No C="3"/>
   <Name>Srilanka</Name>
</Country>
<Country>
   <No C="4"/>
   <Name>Thailand</Name>
</Country>
</Countries>

XML 文件 - 2

<Capitals>
  <Capital>
      <No C="1"/>
      <Name>New Delhi</Name>
  </Capital>
  <Capital>
      <No C="2"/>
      <Name>Washington DC</Name>
  </Capital>
  <Capital>
      <No C="3"/>
      <Name>Colombo</Name>
  </Capital>
  <Capital>
      <No C="4"/>
      <Name>Bangkok</Name>
  </Capital>
</Capitals>

所需的输出 -

India - New Delhi
USA - Washington DC
Srilanka - Colombo
Thailand - Bangkok

我尝试过的就像,但无法获得所需的输出:(

for $x in doc('Country')/Countries
  return 
  <a>
 {$x/Country/Name}
 {
   for $y in doc('Capital')/Capitals
   where $y/Capital/No/@C = $x/Country/No/@C
    return $y/Capital/Name
  }
  </a>
4

2 回答 2

3

我得到了答案,它是——

谓词中的双向连接 -

for $x in doc('country')//Country
  return 
  string-join( ($x/Name/text(),  
     for $y in doc('capital')//Capital
       where $y/No/@C = $x/No/@C
       return $y/Name/text()
                ), " - ")
于 2012-10-19T09:05:42.880 回答
2

您的答案产生了正确的结果,但是我发现以下语法(使用 XPath 而不是另一个 FLOWR 表达式)要简单得多:

for $x in doc('country')//Country
return 
  string-join( ($x/Name/text(),  
    $doc('capital')//Capital[./No/@C = $x/No/@C]/Name/text()
            ), " - ")
于 2012-10-19T09:59:45.093 回答