开发者

using an attribute name in an xQuery

I have this Xml:

<Item key = "id">
   <SubItem开发者_运维知识库 id = "1" a = "2"/>
   <SubItem id = "1" b = "3"/>
   <SubItem x = "1"/>
   <SubItem y = "1"/>
   <SubItem z = "1"/>
</Item>

I wish to select the SubItems that have an attribute whose name equals the value of (.) key

I want a query that returns this:

<SubItem id = "1" a = "2"/>
<SubItem id = "1" b = "3"/>

So I tried:

let $x := ... my xml here...
let $key = $x/@id

return $x/*/@*[name(.) = $key]/..

this works...

but I wanted something more succinct like:

let $x := ... my xml here...
let $key = $x/@id

return $x/*/@$key

problem is, that code does not compile because it won't let me use a non literal (or wildcard) after the @.

Is it really impossible? Thanks in advance!!


You didn't mention what system you're using, but there is a MarkLogic-specific way to do this:

let $data :=
  <Item key = "id">
   <SubItem id = "1" a = "2"/>
   <SubItem id = "1" b = "3"/>
   <SubItem x = "1"/>
   <SubItem y = "1"/>
   <SubItem z = "1"/>
  </Item>
let $path := fn:concat("$data/SubItem[exists(./@", fn:data($data/@key), ")]")
return xdmp:value($path)

As far as I know, standard XQuery doesn't have a simpler way than what you did. Other systems may have similar extensions.

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜