Проверка отсутствия атрибута с помощью cts:query

У меня есть фрагмент XML, где я хочу иметь разные запросы, основанные на существовании атрибута id:

<author order="1" 
        id="99999999" 
        initials="A." 
        given-names="Able" 
        surname="Baker" 
        fullname="Able Baker"/>

Я пытался:

let $first-query := if ($first)
                then cts:or-query((
                    cts:element-attribute-word-match(xs:QName("author"), xs:QName("given-names"), $first || "*", ("collation=http://marklogic.com/collation/codepoint")),
                    cts:element-attribute-word-match(xs:QName("author"), xs:QName("initials"), $first || "*", ("collation=http://marklogic.com/collation/codepoint"))
                     ))
                else ()

let $last-query := if ($last)
               then cts:element-attribute-word-match(xs:QName("author"), xs:QName("surname"), $last || "*", ("collation=http://marklogic.com/collation/codepoint"))
               else ()

let $author-no-id-query := 
    cts:and-query((
        cts:not-query(
            cts:element-attribute-value-query(xs:QName("author"), xs:QName("id"), "*")
        ),
        $first-query,
        $last-query
    ))

let $query :=    cts:element-query(xs:QName("author"),
                 cts:or-query(($author-no-id-query, $author-id-query
                    )))

Если идентификатор существует, то выполняется другой запрос и выполняется сопоставление с идентификатором. Как обнаружить отсутствие атрибута в MarkLogic?

1 ответ

Решение

Я вставил два тестовых документа в базу данных:

xdmp:document-insert('/example.xml', <author order="1"
        id="99999999"
        initials="A." 
        given-names="Able" 
        surname="Baker" 
        fullname="Able Baker"/>)

xdmp:document-insert('/example2.xml', <author order="1" 
        initials="A." 
        given-names="Able" 
        surname="Baker" 
        fullname="Able Baker"/>)

И выполните следующий запрос к этим документам:

cts:search(fn:doc(),
cts:element-query(xs:QName('author'), cts:and-query((
  cts:not-query(cts:element-attribute-value-query(xs:QName('author'), xs:QName('id'), '*', ("wildcarded")))
 )
)))

Этот поиск соответствует только документу, где атрибут ID не существует.

Другие вопросы по тегам