Повторные данные в XML - PullRequest
       18

Повторные данные в XML

0 голосов
/ 23 марта 2011

Как мне получить данные (), которые не повторяются в переменной.

Я использую эту функцию:

.
.
.
let $person:= $hopital1/persona
    for $seq in (1 to count($derechohabiente))
    return
       $person[$seq]
       [not(xf:is-node-secuence-equal(.,$person[position() < $seq])) ]

declare function xf:is-node-secuence-equal ( $node as node()? , $seq as node()*)  as xs:boolean {
    some $nodeInSeq in $seq satisfies fn:deep-equal($nodeInSeq/name, $node/ns0:name)
};
.
.
.

Это пример XML, я просто хочу получитьИнформация Джозефа, но я получаю только данные, повторенные

<?xml version="1.0"?>
<hospital>
    <person>
        <idee>1902</idee>
        <name>Joseph</name>
        <age>60</age>
        <room>4</room>
        <service>false</service>        
    </person>
    <person>
        <idee>3246</idee>
        <name>John</name>
        <age>34</age>
        <room>0</room>
        <service>false</service>        
    </person>
    <person>
        <idee>3246</idee>
        <name>John</name>
        <age>34</age>
        <room>0</room>
        <service>true</service>        
    </person>
    <person>
        <idee>3246</idee>
        <name>John</name>
        <age>34</age>
        <room>5</room>
        <service>true</service>        
    </person>
</hospital>

Обновление по комментариям

Я хочу получить данные, которые не повторяются;если вы видите пример XML, вот результат, который я хотел бы получить:

<hospital>
    <person>
        <idee>1902</idee>
        <name>Joseph</name>
        <age>60</age>
        <room>4</room>
        <service>false</service>
    </person>
</hospital>

1 Ответ

1 голос
/ 23 марта 2011

Два выражения XQuery:

/hospital/person[not(name = (../person except .)/name)]

И

/hospital/person[not(index-of(../person/name,name)[2])]
...