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

Fra*_*z B 2 marklogic marklogic-9


在托管 (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
Run Code Online (Sandbox Code Playgroud)

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

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

grt*_*tjn 5

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

我建议切换到 using 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
  )
) 
Run Code Online (Sandbox Code Playgroud)

哼!