Come Inserire un nuovo nodo elastico nidificati atributte

0

Domanda

Descrivo un POC del mio problema. Ho questo indice mapping:

{
    "properties": {
        "level_l": {
            "type": "nested",
            "properties": {
                "level_2-1": {
                    "type": "keyword"
                },
                "level_2-2":{
                    "type": "nested",
                    "properties": {
                        "level_3-1": {
                            "type": "keyword"
                        },
                        "level_3-2": {
                            "type": "keyword"
                        },
                        "level_3-3": {
                            "type": "keyword"
                        }
                    }
                }
            }
        }
    }
}

E l'aggiunta di questo documento:

{
    "level_1": [
        {
            "level_2-1": "a",
            "level_2-2": [
                {
                    "level_3-1": "c1",
                    "level_3-2": "c2",
                    "level_3-3": "c3"
                }
            ]
        },
        {
            "level_2-1": "b",
            "level_2-2": [
                {
                    "level_3-1": "c1",
                    "level_3-2": "c2",
                    "level_3-3": "c3"
                }
            ]
        }
    ]
}

Ho bisogno di aggiungere un nuovo nodo in level_2-2, quando level_2-1 = a. Ho provato usando come guida le note https://iridakos.com/programming/2019/05/02/add-update-delete-elasticsearch-nested-objects ma non ho potuto.

Tutte le idee?

1

Migliore risposta

0

Come mostrato nel tutorial è collegato, è necessario l'ID dell'oggetto che si desidera modificare. Prendendo ad esempio da qui:

POST iridakos_nested_objects/human/1/_update
{
  "script": {
    "source": "ctx._source.cats.add(params.cat)",
    "params": {
      "cat": {
        "colors": 4,
        "name": "Leon",
        "breed": "Persian"
      }
    }
  }
}

Nell'esempio di cui sopra, 1 è l'ID del record. È necessario sostituirlo con il record che si desidera modificare.

Nel caso In cui si desideri modificare tutti i record, è necessario utilizzare il update_by_query API. La mappatura di questo esempio il tutorial di cui sopra, potrebbe assomigliare a questo:

POST INDEX_NAME_HERE/_update_by_query
{
  "script": {
    "source": "ctx._source.cats.add(params.cat)",
    "params": {
      "cat": {
        "colors": 4,
        "name": "Leon",
        "breed": "Persian"
      }
    }
  },
  "query": {
    "match_all": {}
  }
}

In questo caso, avete bisogno di aggiornare la query parte (alla fine) per tutti i record che si desidera aggiornare. Credo che si sarebbe probabilmente piace query nidificata oggetto, anche se la sua non è evidente dalla sua domanda.

2021-11-22 13:11:25

In altre lingue

Questa pagina è in altre lingue

Русский
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................