问题描述
正如标题所述,我正在尝试使用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_exception
。 Investigating 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()