Explicit mapping

Explicit mapping

You know more about your data than Elasticsearch can guess, so while dynamic mapping can be useful to get started, at some point you will want to specify your own explicit mappings.

You can create field mappings when you create an index and add fields to an existing index.

Create an index with an explicit mapping

You can use the create index API to create a new index with an explicit mapping.

  1. resp = client.indices.create(
  2. index="my-index-000001",
  3. mappings={
  4. "properties": {
  5. "age": {
  6. "type": "integer"
  7. },
  8. "email": {
  9. "type": "keyword"
  10. },
  11. "name": {
  12. "type": "text"
  13. }
  14. }
  15. },
  16. )
  17. print(resp)
  1. response = client.indices.create(
  2. index: 'my-index-000001',
  3. body: {
  4. mappings: {
  5. properties: {
  6. age: {
  7. type: 'integer'
  8. },
  9. email: {
  10. type: 'keyword'
  11. },
  12. name: {
  13. type: 'text'
  14. }
  15. }
  16. }
  17. }
  18. )
  19. puts response
  1. res, err := es.Indices.Create(
  2. "my-index-000001",
  3. es.Indices.Create.WithBody(strings.NewReader(`{
  4. "mappings": {
  5. "properties": {
  6. "age": {
  7. "type": "integer"
  8. },
  9. "email": {
  10. "type": "keyword"
  11. },
  12. "name": {
  13. "type": "text"
  14. }
  15. }
  16. }
  17. }`)),
  18. )
  19. fmt.Println(res, err)
  1. const response = await client.indices.create({
  2. index: "my-index-000001",
  3. mappings: {
  4. properties: {
  5. age: {
  6. type: "integer",
  7. },
  8. email: {
  9. type: "keyword",
  10. },
  11. name: {
  12. type: "text",
  13. },
  14. },
  15. },
  16. });
  17. console.log(response);
  1. PUT /my-index-000001
  2. {
  3. "mappings": {
  4. "properties": {
  5. "age": { "type": "integer" },
  6. "email": { "type": "keyword" },
  7. "name": { "type": "text" }
  8. }
  9. }
  10. }

Creates age, an integer field

Creates email, a keyword field

Creates name, a text field

Add a field to an existing mapping

You can use the update mapping API to add one or more new fields to an existing index.

The following example adds employee-id, a keyword field with an index mapping parameter value of false. This means values for the employee-id field are stored but not indexed or available for search.

  1. resp = client.indices.put_mapping(
  2. index="my-index-000001",
  3. properties={
  4. "employee-id": {
  5. "type": "keyword",
  6. "index": False
  7. }
  8. },
  9. )
  10. print(resp)
  1. response = client.indices.put_mapping(
  2. index: 'my-index-000001',
  3. body: {
  4. properties: {
  5. "employee-id": {
  6. type: 'keyword',
  7. index: false
  8. }
  9. }
  10. }
  11. )
  12. puts response
  1. res, err := es.Indices.PutMapping(
  2. []string{"my-index-000001"},
  3. strings.NewReader(`{
  4. "properties": {
  5. "employee-id": {
  6. "type": "keyword",
  7. "index": false
  8. }
  9. }
  10. }`),
  11. )
  12. fmt.Println(res, err)
  1. const response = await client.indices.putMapping({
  2. index: "my-index-000001",
  3. properties: {
  4. "employee-id": {
  5. type: "keyword",
  6. index: false,
  7. },
  8. },
  9. });
  10. console.log(response);
  1. PUT /my-index-000001/_mapping
  2. {
  3. "properties": {
  4. "employee-id": {
  5. "type": "keyword",
  6. "index": false
  7. }
  8. }
  9. }

Update the mapping of a field

Except for supported mapping parameters, you can’t change the mapping or field type of an existing field. Changing an existing field could invalidate data that’s already indexed.

If you need to change the mapping of a field in a data stream’s backing indices, see Change mappings and settings for a data stream.

If you need to change the mapping of a field in other indices, create a new index with the correct mapping and reindex your data into that index.

Renaming a field would invalidate data already indexed under the old field name. Instead, add an alias field to create an alternate field name.

View the mapping of an index

You can use the get mapping API to view the mapping of an existing index.

  1. resp = client.indices.get_mapping(
  2. index="my-index-000001",
  3. )
  4. print(resp)
  1. response = client.indices.get_mapping(
  2. index: 'my-index-000001'
  3. )
  4. puts response
  1. res, err := es.Indices.GetMapping(es.Indices.GetMapping.WithIndex("my-index-000001"))
  2. fmt.Println(res, err)
  1. const response = await client.indices.getMapping({
  2. index: "my-index-000001",
  3. });
  4. console.log(response);
  1. GET /my-index-000001/_mapping

The API returns the following response:

  1. {
  2. "my-index-000001" : {
  3. "mappings" : {
  4. "properties" : {
  5. "age" : {
  6. "type" : "integer"
  7. },
  8. "email" : {
  9. "type" : "keyword"
  10. },
  11. "employee-id" : {
  12. "type" : "keyword",
  13. "index" : false
  14. },
  15. "name" : {
  16. "type" : "text"
  17. }
  18. }
  19. }
  20. }
  21. }

View the mapping of specific fields

If you only want to view the mapping of one or more specific fields, you can use the get field mapping API.

This is useful if you don’t need the complete mapping of an index or your index contains a large number of fields.

The following request retrieves the mapping for the employee-id field.

  1. resp = client.indices.get_field_mapping(
  2. index="my-index-000001",
  3. fields="employee-id",
  4. )
  5. print(resp)
  1. response = client.indices.get_field_mapping(
  2. index: 'my-index-000001',
  3. fields: 'employee-id'
  4. )
  5. puts response
  1. res, err := es.Indices.GetMapping(es.Indices.GetMapping.WithIndex("my-index-000001"))
  2. fmt.Println(res, err)
  1. const response = await client.indices.getFieldMapping({
  2. index: "my-index-000001",
  3. fields: "employee-id",
  4. });
  5. console.log(response);
  1. GET /my-index-000001/_mapping/field/employee-id

The API returns the following response:

  1. {
  2. "my-index-000001" : {
  3. "mappings" : {
  4. "employee-id" : {
  5. "full_name" : "employee-id",
  6. "mapping" : {
  7. "employee-id" : {
  8. "type" : "keyword",
  9. "index" : false
  10. }
  11. }
  12. }
  13. }
  14. }
  15. }