Elasticsearch Aggregation. Nach verschachteltem Bucket bestellen doc_count

Was ich erreichen möchte, ist die Aggregation nach eindeutigen Paaren (Stadt, STAAT). Gemäß Elasticsearch-Dokumentation Die Termaggregation unterstützt nicht das Sammeln von Begriffen aus mehreren Feldern im selben Dokument.. So habe ich ein verschachteltes Agg wie folgt erstellt:

{
  "size": 0,
  "aggs": {
    "cities": {
      "terms": {
        "field": "address.city",
        "size": 12
      },
      "aggs": {
        "states": {
          "terms": {
            "field": "address.stateOrProvince"
          },
          "aggs": {
            "topCity": {
              "top_hits": {
                "size": 1,
                "sort": [
                  {
                    "price.value": {
                      "order": "desc" }}]}}}}}}}}

ls Ergebnis dieser Aggregation erhalte ich folgende Antwort:

{
  "aggregations": {
    "cities": {
      "buckets": [
        {
          "key": "las vegas",
          "doc_count": 5927,
          "states": {
            "buckets": [
              { "key": "nv", "doc_count": 5840 },
              { "key": "nm", "doc_count": 85 }
            ]
          }
        },
        {
          "key": "jacksonville",
          "doc_count": 5689,
          "states": {
            "buckets": [
              { "key": "fl", "doc_count": 2986 },
              { "key": "nc", "doc_count": 1962 },
              { "key": "ar", "doc_count": 290 }]}}]}}}

Die Frage ist, wie die Ergebnisse nach dem tiefsten doc_count sortiert werden.

Erwartete geordnete Liste sollte folgendermaßen aussehen:

las vegas, nv (5840)jacksonville, fl (2986)acksonville, NC (196jacksonville, ar (290)las vegas, nm (85)

Antworten auf die Frage(4)

Ihre Antwort auf die Frage