where operator in APL is used to filter rows based on specified conditions. You can use the where operator to return only the records that meet the criteria you define. It’s a foundational operator in querying datasets, helping you focus on specific data by applying conditions to filter out unwanted rows. This is useful when working with large datasets, logs, traces, or security events, allowing you to extract meaningful information quickly.
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.Splunk SPL users
Splunk SPL users
In Splunk SPL, the 
where operator filters events based on boolean expressions. APL’s where operator functions similarly, allowing you to filter rows that satisfy a condition.ANSI SQL users
ANSI SQL users
In ANSI SQL, the 
WHERE clause filters rows in a SELECT query based on a condition. APL’s where operator behaves similarly, but the syntax reflects APL’s specific dataset structures.Usage
Syntax
Parameters
- condition: A Boolean expression that specifies the filtering condition. The- whereoperator returns only the rows that satisfy this condition.
Returns
Thewhere operator returns a filtered dataset containing only the rows where the condition evaluates to true.
Use case examples
- Log analysis
- OpenTelemetry traces
- Security logs
In this use case, you filter HTTP logs to focus on records where the HTTP status is 404 (Not Found).QueryRun in PlaygroundOutput
This query filters out all HTTP requests except those that resulted in a 404 error, making it easy to investigate pages that were not found.
| _time | id | status | method | uri | req_duration_ms | geo.city | geo.country | 
|---|---|---|---|---|---|---|---|
| 2024-10-17 10:20:00 | 12345 | 404 | GET | /notfound.html | 120 | Seattle | US | 
where * has
The* has pattern in APL is a dynamic and powerful tool within the where operator. It offers you the flexibility to search for specific substrings across all fields in a dataset without the need to specify each field name individually. This becomes especially advantageous when dealing with datasets that have numerous or dynamically named fields.
where * has is an expensive operation because it searches all fields. For a more efficient query, explicitly list the fields in which you want to search. For example: where firstName has "miguel" or lastName has "miguel".
Basic where * has usage
Find events where any field contains a specific substring.Combine multiple substrings
Find events where any field contains one of multiple substrings.Use * has with other operators
Find events where any field contains a substring, and another specific field equals a certain value.Advanced chaining
Filter data based on several conditions, including fields containing certain substrings, then summarize by another specific criterion.Use with aggregations
Find the average of a specific field for events where any field contains a certain substring.String case transformation
Thehas operator is case insensitive. Use has if you’re unsure about the case of the substring in the dataset. For the case-sensitive operator, use has_cs.