Ignored

The _ignored field helps you manage issues related to malformed data in your documents. This field is used to index and store field names that were ignored during the indexing process as a result of the ignore_malformed setting being enabled in the index mapping.

The _ignored field allows you to search for and identify documents containing fields that were ignored as well as for the specific field names that were ignored. This can be useful for troubleshooting.

You can query the _ignored field using the term, terms, and exists queries, and the results will be included in the search hits.

The _ignored field is only populated when the ignore_malformed setting is enabled in your index mapping. If ignore_malformed is set to false (the default value), then malformed fields will cause the entire document to be rejected, and the _ignored field will not be populated.

The following example request shows you how to use the _ignored field:

  1. GET _search
  2. {
  3. "query": {
  4. "exists": {
  5. "field": "_ignored"
  6. }
  7. }
  8. }

copy


Example indexing request with the _ignored field

The following example request adds a new document to the test-ignored index with ignore_malformed set to true so that no error is thrown during indexing:

  1. PUT test-ignored
  2. {
  3. "mappings": {
  4. "properties": {
  5. "title": {
  6. "type": "text"
  7. },
  8. "length": {
  9. "type": "long",
  10. "ignore_malformed": true
  11. }
  12. }
  13. }
  14. }
  15. POST test-ignored/_doc
  16. {
  17. "title": "correct text",
  18. "length": "not a number"
  19. }
  20. GET test-ignored/_search
  21. {
  22. "query": {
  23. "exists": {
  24. "field": "_ignored"
  25. }
  26. }
  27. }

copy

Example reponse

  1. {
  2. "took": 42,
  3. "timed_out": false,
  4. "_shards": {
  5. "total": 1,
  6. "successful": 1,
  7. "skipped": 0,
  8. "failed": 0
  9. },
  10. "hits": {
  11. "total": {
  12. "value": 1,
  13. "relation": "eq"
  14. },
  15. "max_score": 1,
  16. "hits": [
  17. {
  18. "_index": "test-ignored",
  19. "_id": "qcf0wZABpEYH7Rw9OT7F",
  20. "_score": 1,
  21. "_ignored": [
  22. "length"
  23. ],
  24. "_source": {
  25. "title": "correct text",
  26. "length": "not a number"
  27. }
  28. }
  29. ]
  30. }
  31. }

Ignoring a specified field

You can use a term query to find documents in which a specific field was ignored, as shown in the following example request:

  1. GET _search
  2. {
  3. "query": {
  4. "term": {
  5. "_ignored": "created_at"
  6. }
  7. }
  8. }

copy

Reponse

  1. {
  2. "took": 51,
  3. "timed_out": false,
  4. "_shards": {
  5. "total": 45,
  6. "successful": 45,
  7. "skipped": 0,
  8. "failed": 0
  9. },
  10. "hits": {
  11. "total": {
  12. "value": 0,
  13. "relation": "eq"
  14. },
  15. "max_score": null,
  16. "hits": []
  17. }
  18. }