From 021999f265bfa0af62527e7e63a87e6b72e36362 Mon Sep 17 00:00:00 2001 From: cwillum <107723039+cwillum@users.noreply.github.com> Date: Mon, 8 Aug 2022 13:40:00 -0700 Subject: [PATCH] =?UTF-8?q?Revert=20"=E2=80=9Cfix#829-PreAgg-field=5Fdoc?= =?UTF-8?q?=5Fcount=E2=80=9D=20(#839)"=20(#860)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit This reverts commit 07eda05688afd17ef37b1f4d4d9255a0686abcda. --- _opensearch/bucket-agg.md | 86 --------------------------------------- 1 file changed, 86 deletions(-) diff --git a/_opensearch/bucket-agg.md b/_opensearch/bucket-agg.md index 5714f7f4..1f73fb4b 100644 --- a/_opensearch/bucket-agg.md +++ b/_opensearch/bucket-agg.md @@ -74,92 +74,6 @@ The `terms` aggregation requests each shard for its top 3 unique terms. The coor This is especially true if `size` is set to a low number. Because the default size is 10, an error is unlikely to happen. If you don’t need high accuracy and want to increase the performance, you can reduce the size. -### Account for pre-aggregated data - -While the `doc_count` field provides a representation of the number of individual documents aggregated in a bucket, `doc_count` by itself does not have a way to correctly increment documents that store pre-aggregated data. To account for pre-aggregated data and accurately calculate the number of documents in a bucket, you can use the `_doc_count` field to add the number of documents in a single summary field. When a document includes the `_doc_count` field, all bucket aggregations recognize its value and increase the bucket `doc_count` cumulatively. Keep these considerations in mind when using the `_doc_count` field: - -* The field does not support nested arrays; only positive integers can be used. -* If a document does not contain the `_doc_count` field, aggregation uses the document to increase the count by 1. - -OpenSearch features that rely on an accurate document count illustrate the importance of using the `_doc_count` field. To see how this field can be used to support other search tools, refer to [Index rollups](https://opensearch.org/docs/latest/im-plugin/index-rollups/index/), an OpenSearch feature for the Index Management (IM) plugin that stores documents with pre-aggregated data in rollup indexes. -{: .tip} - -### Example usage - -```json -PUT /my_index/_doc/1 -{ - "response_code": 404, - "date":"2022-08-05", - "_doc_count": 20 -} - -PUT /my_index/_doc/2 -{ - "response_code": 404, - "date":"2022-08-06", - "_doc_count": 10 -} - -PUT /my_index/_doc/3 -{ - "response_code": 200, - "date":"2022-08-06", - "_doc_count": 300 -} - -GET /my_index/_search -{ - "size": 0, - "aggs": { - "response_codes": { - "terms": { - "field" : "response_code" - } - } - } -} -``` - -#### Sample response - -```json -{ - "took" : 20, - "timed_out" : false, - "_shards" : { - "total" : 1, - "successful" : 1, - "skipped" : 0, - "failed" : 0 - }, - "hits" : { - "total" : { - "value" : 3, - "relation" : "eq" - }, - "max_score" : null, - "hits" : [ ] - }, - "aggregations" : { - "response_codes" : { - "doc_count_error_upper_bound" : 0, - "sum_other_doc_count" : 0, - "buckets" : [ - { - "key" : 200, - "doc_count" : 300 - }, - { - "key" : 404, - "doc_count" : 30 - } - ] - } - } -} -``` - ## Multi-terms Similar to the `terms` bucket aggregation, you can also search for multiple terms using the `multi_terms` aggregation. Multi-terms aggregations are useful when you need to sort by document count, or when you need to sort by a metric aggregation on a composite key and get the top `n` results. For example, you could search for a specific number of documents (e.g., 1000) and the number of servers per location that show CPU usage greater than 90%. The top number of results would be returned for this multi-term query.