_ignored field

_ignored field

The _ignored field indexes and stores the names of every field in a document that has been ignored when the document was indexed. This can, for example, be the case when the field was malformed and ignore_malformed was turned on, when a keyword field’s value exceeds its optional ignore_above setting, or when index.mapping.total_fields.limit has been reached and index.mapping.total_fields.ignore_dynamic_beyond_limit is set to true.

This field is searchable with term, terms and exists queries, and is returned as part of the search hits.

For instance the below query matches all documents that have one or more fields that got ignored:

  1. resp = client.search(
  2. query={
  3. "exists": {
  4. "field": "_ignored"
  5. }
  6. },
  7. )
  8. print(resp)
  1. response = client.search(
  2. body: {
  3. query: {
  4. exists: {
  5. field: '_ignored'
  6. }
  7. }
  8. }
  9. )
  10. puts response
  1. const response = await client.search({
  2. query: {
  3. exists: {
  4. field: "_ignored",
  5. },
  6. },
  7. });
  8. console.log(response);
  1. GET _search
  2. {
  3. "query": {
  4. "exists": {
  5. "field": "_ignored"
  6. }
  7. }
  8. }

Similarly, the below query finds all documents whose @timestamp field was ignored at index time:

  1. resp = client.search(
  2. query={
  3. "term": {
  4. "_ignored": "@timestamp"
  5. }
  6. },
  7. )
  8. print(resp)
  1. response = client.search(
  2. body: {
  3. query: {
  4. term: {
  5. _ignored: '@timestamp'
  6. }
  7. }
  8. }
  9. )
  10. puts response
  1. const response = await client.search({
  2. query: {
  3. term: {
  4. _ignored: "@timestamp",
  5. },
  6. },
  7. });
  8. console.log(response);
  1. GET _search
  2. {
  3. "query": {
  4. "term": {
  5. "_ignored": "@timestamp"
  6. }
  7. }
  8. }

Since 8.15.0, the _ignored field supports aggregations as well. For example, the below query finds all fields that got ignored:

  1. resp = client.search(
  2. aggs={
  3. "ignored_fields": {
  4. "terms": {
  5. "field": "_ignored"
  6. }
  7. }
  8. },
  9. )
  10. print(resp)
  1. response = client.search(
  2. body: {
  3. aggregations: {
  4. ignored_fields: {
  5. terms: {
  6. field: '_ignored'
  7. }
  8. }
  9. }
  10. }
  11. )
  12. puts response
  1. const response = await client.search({
  2. aggs: {
  3. ignored_fields: {
  4. terms: {
  5. field: "_ignored",
  6. },
  7. },
  8. },
  9. });
  10. console.log(response);
  1. GET _search
  2. {
  3. "aggs": {
  4. "ignored_fields": {
  5. "terms": {
  6. "field": "_ignored"
  7. }
  8. }
  9. }
  10. }