首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何删除Marklogic中的数百万个文档

如何删除Marklogic中的数百万个文档
EN

Stack Overflow用户
提问于 2022-11-18 15:47:34
回答 1查看 36关注 0票数 1

我们在Marklogic中搜索并尝试了几种删除文档的方法,但没有找到一种可靠的方法来删除数百万文档,而无需检查它们是否已经被删除。我们发现删除整个集合的方式是使用xdmp:collection-delete函数,但它确实很慢。我们发现的最快的方法是使用下面的XQuery。但是我们必须运行XQuery,等待它完成,检查集合中是否还有任何文档,并重复几次直到所有内容都被删除。

我们根本不擅长编码XQuery,所以我们可能遗漏了一些东西。

Marklogic社区如何快速可靠地删除数百万个文档?

下面是我们使用的XQuery:

代码语言:javascript
复制
xquery version "1.0-ml";
let $page-size := 1000
let $uris := cts:uris('', (), cts:collection-query('OurCollection'))
let $pages := (count($uris) idiv $page-size) + 1
return 
  for $page in (1 to $pages)
  let $start := (($page - 1) * $page-size) + 1 
  let $end := $page * $page-size
  let $uris := subsequence($uris, $start, $end)
  return
    xdmp:spawn-function(function(){
      for $uri in $uris
      return
        xdmp:document-delete($uri)
    });
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-11-18 16:26:07

像您所展示的那样,产生大量的删除是一种方法,而且是最简单的,而且没有任何外部工具。您可以增加任务服务器线程以获得更多的并发性,但仍然需要一段时间。

执行批量活动的另一种非常常见的方法,如删除数百万个文档,是运行一个CoRB作业。您可以控制作业用于并发请求的线程数,并使用负载均衡器或CoRBs多主机负载平衡功能将请求发送到所有E节点。

https://help.marklogic.com/Knowledgebase/Article/View/best-practices-for-improving-the-performance-of-large-collections-deletes

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/74492137

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档