"_missing":"last" 使用org.elasticsearch.search.sort.SortBuilders.fieldSort
时间: 2024-09-23 22:11:58 浏览: 133
elasticsearch-7.4.2-linux-x86_64.tar.gz
在Elasticsearch中,`"_missing": "last"` 是一种排序策略,用于在排序结果中将缺失值(即那些在指定字段上不存在的文档)放在最后。当你在使用 `org.elasticsearch.search.sort.SortBuilders.fieldSort()` 这个方法构建一个基于字段的排序器时,添加了这个选项,意味着在对字段值进行排序时,如果某个文档在这个字段上没有值(即它是空的),它将在所有有该字段值的文档之后。
例如,下面的代码片段展示了如何创建一个按照 'name' 字段排序,同时处理缺失值的 `fieldSort`:
```java
SortField sortField = new SortField("name", SortOrder.ASC);
SortBuilder fieldSort = SortBuilders.fieldSort(sortField).order(SortOrder.UNDEFINED).missing("_last");
SearchResponse response = client.prepareSearch(indexName)
.setTypes(docType)
.addSort(fieldSort)
.execute()
.actionGet();
```
这里,`SortOrder.UNDEFINED` 表示对于缺失的值不设定明确的顺序,也就是应用默认的 `_missing: last` 规则。
阅读全文