| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 | [[search-aggregations-metrics-valuecount-aggregation]]=== Value Count AggregationA `single-value` metrics aggregation that counts the number of values that are extracted from the aggregated documents.These values can be extracted either from specific fields in the documents, or be generated by a provided script. Typically,this aggregator will be used in conjunction with other single-value aggregations. For example, when computing the `avg`one might be interested in the number of values the average is computed over.[source,js]--------------------------------------------------POST /sales/_search?size=0{    "aggs" : {        "types_count" : { "value_count" : { "field" : "type" } }    }}--------------------------------------------------// CONSOLE// TEST[setup:sales]Response:[source,js]--------------------------------------------------{    ...    "aggregations": {        "types_count": {            "value": 7        }    }}--------------------------------------------------// TESTRESPONSE[s/\.\.\./"took": $body.took,"timed_out": false,"_shards": $body._shards,"hits": $body.hits,/]The name of the aggregation (`types_count` above) also serves as the key by which the aggregation result can beretrieved from the returned response.==== ScriptCounting the values generated by a script:[source,js]--------------------------------------------------POST /sales/_search?size=0{    "aggs" : {        "type_count" : {            "value_count" : {                "script" : {                    "source" : "doc['type'].value"                }            }        }    }}--------------------------------------------------// CONSOLE// TEST[setup:sales]This will interpret the `script` parameter as an `inline` script with the `painless` script language and no script parameters. To use a stored script use the following syntax:[source,js]--------------------------------------------------POST /sales/_search?size=0{    "aggs" : {        "types_count" : {            "value_count" : {                "script" : {                    "id": "my_script",                    "params" : {                        "field" : "type"                    }                }            }        }    }}--------------------------------------------------// CONSOLE// TEST[setup:sales,stored_example_script]
 |