温馨提示:本文翻译自stackoverflow.com,查看原文请点击:其他 - Marklogic using xPath on managed documents results in all versions of this documents
marklogic marklogic-9

其他 - 在托管文档上使用xPath的Marklogic会生成此文档的所有版本

发布于 2020-04-28 16:58:58


在托管(dls:document-insert-and-manage(...))文档上使用xpath时,我想在此文档上使用xpath表达式仅检索实际文档,尤其是其他用户。

使用xpath,我可以获取文档的所有版本,也可以获取文档。

我尝试在文档上设置权限。
限制URI仅用于创建。
保护路径无济于事,因为所有版本的xpath都相同。

是否有可能限制某些用户只能获取最新版本?

我们正在使用Marklogic 9.0.8

例:

设定文件

xquery version "1.0-ml";
import module namespace dls = "http://marklogic.com/xdmp/dls" at "/MarkLogic/dls.xqy";

declare variable $uri :="/smtextdocuments/9114.xml";
declare variable $document := document {
<envelope>
  <instance>
    <smtextdocuments>
      <uri>/smtextdocuments/9114.xml</uri><id>9114</id>
      <documentcontent>MyText</documentcontent>
    </smtextdocuments>
  </instance>
</envelope>
};

let $d := dls:document-insert-and-manage($uri,fn:true(), $document,
        "Manage textdocuments",
        (
         xdmp:permission("dls-user", "read"),
         xdmp:permission("dls-internal", "read"),
         xdmp:permission("dls-internal", "update")),
        ()
        )
return $d

检索文档时导致2个元素或无元素,具体取决于实际用户的权限

xquery version "1.0-ml";
<queryresult>
  <byxPath>{
    for $i in //smtextdocuments[id=9114]
    return (<uri>{fn:base-uri($i)}</uri>,$i)
    }
  </byxPath>
</queryresult>

查看更多

提问者
Franz B
被浏览
73
grtjn 2020-02-10 20:58

您正在使用DLS并行存储一个文档的多个版本,因此,如果您查询整个数据库(如果使用诸如的绝对路径这样的情况,则会发生此情况//xxx),您将获得该文档的所有匹配版本。

我建议切换到使用cts:search,例如与结合使用dls:documents-query()如果您还添加的路径索引smtextdocuments/id,则可以准确地定位文档:

import module namespace dls = "http://marklogic.com/xdmp/dls" 
  at "/MarkLogic/dls.xqy";

cts:search(collection(), cts:and-query((
  dls:documents-query(),
  cts:range-query(
    cts:path-reference('smtextdocuments/id'),
    '=',
    9114
  )
) 

HTH!