The extend operator in APL allows you to create new calculated fields in your result set based on existing data. You can define expressions or functions to compute new values for each row, making extend particularly useful when you need to enrich your data without altering the original dataset. You typically use extend when you want to add additional fields to analyze trends, compare metrics, or generate new insights from your data.

For users of other query languages

If you come from other query languages, this section explains how to adjust your existing queries to achieve the same results in APL.

Usage

Syntax

| extend NewField = Expression

Parameters

  • NewField: The name of the new field to be created.
  • Expression: The expression used to compute values for the new field. This can include mathematical operations, string manipulations, or functions.

Returns

The operator returns a copy of the original dataset with the following changes:

  • Field names noted by extend that already exist in the input are removed and appended as their new calculated values.
  • Field names noted by extend that do not exist in the input are appended as their new calculated values.

Use case examples

In log analysis, you can use extend to compute the duration of each request in seconds from a millisecond value.

Query

['sample-http-logs'] 
| extend duration_sec = req_duration_ms / 1000

Run in Playground

Output

_timereq_duration_msidstatusurimethodgeo.citygeo.countryduration_sec
2024-10-17 09:00:013001234200/homeGETLondonUK0.3

This query calculates the duration of HTTP requests in seconds by dividing the req_duration_ms field by 1000.

  • project: Use project to select specific fields or rename them. Unlike extend, it does not add new fields.
  • summarize: Use summarize to aggregate data, which differs from extend that only adds new calculated fields without aggregation.