Dynamic mapping

Dynamic mapping

One of the most important features of Elasticsearch is that it tries to get out of your way and let you start exploring your data as quickly as possible. To index a document, you don’t have to first create an index, define a mapping type, and define your fields — you can just index a document and the index, type, and fields will display automatically:

  1. resp = client.index(
  2. index="data",
  3. id="1",
  4. document={
  5. "count": 5
  6. },
  7. )
  8. print(resp)
  1. response = client.index(
  2. index: 'data',
  3. id: 1,
  4. body: {
  5. count: 5
  6. }
  7. )
  8. puts response
  1. const response = await client.index({
  2. index: "data",
  3. id: 1,
  4. document: {
  5. count: 5,
  6. },
  7. });
  8. console.log(response);
  1. PUT data/_doc/1
  2. { "count": 5 }

Creates the data index, the _doc mapping type, and a field called count with data type long.

The automatic detection and addition of new fields is called dynamic mapping. The dynamic mapping rules can be customized to suit your purposes with:

Dynamic field mappings

The rules governing dynamic field detection.

Dynamic templates

Custom rules to configure the mapping for dynamically added fields.

Index templates allow you to configure the default mappings, settings and aliases for new indices, whether created automatically or explicitly.