ES|QL metadata fields

ES|QL metadata fields

ES|QL can access metadata fields. The currently supported ones are:

  • _index: the index to which the document belongs. The field is of the type keyword.
  • _id: the source document’s ID. The field is of the type keyword.
  • _version: the source document’s version. The field is of the type long.
  • _ignored: the ignored source document fields. The field is of the type keyword.

To enable the access to these fields, the FROM source command needs to be provided with a dedicated directive:

  1. FROM index METADATA _index, _id

Metadata fields are only available if the source of the data is an index. Consequently, FROM is the only source commands that supports the METADATA directive.

Once enabled, these fields will be available to subsequent processing commands, just like other index fields:

  1. FROM ul_logs, apps METADATA _index, _version
  2. | WHERE id IN (13, 14) AND _version == 1
  3. | EVAL key = CONCAT(_index, "_", TO_STR(id))
  4. | SORT id, _index
  5. | KEEP id, _index, _version, key
id:long_index:keyword_version:longkey:keyword

13

apps

1

apps_13

13

ul_logs

1

ul_logs_13

14

apps

1

apps_14

14

ul_logs

1

ul_logs_14

Similar to index fields, once an aggregation is performed, a metadata field will no longer be accessible to subsequent commands, unless used as a grouping field:

  1. FROM employees METADATA _index, _id
  2. | STATS max = MAX(emp_no) BY _index
max:integer_index:keyword

10100

employees