使用Jest在Elasticsearch中删除没有父项的子文档

问题描述

正如标题所述,我正在尝试使用Jest删除所有无父母的子文档。如果一切正确,则需要使用DeleteByQuery,建议的解决方案是:

val allParentlessChildren = QueryBuilders
    .boolQuery()
    .mustNot(JoinQueryBuilders.hasParentQuery(
      "my_parent",QueryBuilders.matchAllQuery(),false)
    )
val delete = new DeleteByQuery.Builder(allParentlessChildren.toString)
    .addindex("my_index")
    .addType("my_child")
    .build()

但是,我得到routing_missing_exceptionInvestigating online,似乎我需要设置路由的父类型,但是,除了在hasParentQuery idk中指定它之外,还需要在其他地方添加它吗?

尽管我找到了some examples如何使用REST API进行操作,但我找不到使用Jest的人,所以希望有人可以提供帮助。

我正在使用Elasticsearch 5.5。

解决方法

只需要添加路由,但是在Jest中,它似乎在setParameter方法中略有隐藏:

val delete = new DeleteByQuery.Builder(allParentlessChildren.toString)
    .addIndex("my_index")
    .addType("my_child")
    .setParameter(Parameters.ROUTING,"my_parent") // <-- added line
    .build()

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...