在托管(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>
您正在使用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!
所以有没有可能限制绝对路径的结果?
有办法,但是笨拙得多。使用搜索作为基础还将允许更好的扩展。