mirror of https://github.com/apache/druid.git
79 lines
2.3 KiB
Markdown
79 lines
2.3 KiB
Markdown
---
|
|
layout: doc_page
|
|
---
|
|
TopNMetricSpec
|
|
==================
|
|
|
|
The topN metric spec specifies how topN values should be sorted.
|
|
|
|
## Numeric TopNMetricSpec
|
|
|
|
The simplest metric specification is a String value indicating the metric to sort topN results by. They are included in a topN query with:
|
|
|
|
```json
|
|
"metric": "<metric_name>"
|
|
```
|
|
|
|
The metric field can also be given as a JSON object. The grammar for dimension values sorted by numeric value is shown below:
|
|
|
|
```json
|
|
"metric": {
|
|
"type": "numeric",
|
|
"metric": "<metric_name>"
|
|
}
|
|
```
|
|
|
|
|property|description|required?|
|
|
|--------|-----------|---------|
|
|
|type|this indicates a numeric sort|yes|
|
|
|metric|the actual metric field in which results will be sorted by|yes|
|
|
|
|
## Lexicographic TopNMetricSpec
|
|
|
|
The grammar for dimension values sorted lexicographically is as follows:
|
|
|
|
```json
|
|
"metric": {
|
|
"type": "lexicographic",
|
|
"previousStop": "<previousStop_value>"
|
|
}
|
|
```
|
|
|
|
|property|description|required?|
|
|
|--------|-----------|---------|
|
|
|type|this indicates a lexicographic sort|yes|
|
|
|previousStop|the starting point of the lexicographic sort. For example, if a previousStop value is 'b', all values before 'b' are discarded. This field can be used to paginate through all the dimension values.|no|
|
|
|
|
## AlphaNumeric TopNMetricSpec
|
|
|
|
Sort dimension values in alpha-numeric order, i.e treating numbers differently from other characters in sorting the values.
|
|
The algorithm is based on [https://github.com/amjjd/java-alphanum](https://github.com/amjjd/java-alphanum).
|
|
|
|
```json
|
|
"metric": {
|
|
"type": "alphaNumeric",
|
|
"previousStop": "<previousStop_value>"
|
|
}
|
|
```
|
|
|
|
|property|description|required?|
|
|
|--------|-----------|---------|
|
|
|type|this indicates an alpha-numeric sort|yes|
|
|
|previousStop|the starting point of the alpha-numeric sort. For example, if a previousStop value is 'b', all values before 'b' are discarded. This field can be used to paginate through all the dimension values.|no|
|
|
|
|
## Inverted TopNMetricSpec
|
|
|
|
Sort dimension values in inverted order, i.e inverts the order of the delegate metric spec. It can be used to sort the values in descending order.
|
|
|
|
```json
|
|
"metric": {
|
|
"type": "inverted",
|
|
"metric": <delegate_top_n_metric_spec>
|
|
}
|
|
```
|
|
|
|
|property|description|required?|
|
|
|--------|-----------|---------|
|
|
|type|this indicates an inverted sort|yes|
|
|
|metric|the delegate metric spec. |yes|
|