datetime_diff function in APL to calculate the calendarian difference between two datetime values in a specified unit. The function computes datetime1 - datetime2 and returns the result as a count of the specified date part.
You can use datetime_diff to measure elapsed time between events, calculate how long ago something occurred, or compare timestamps across records.
Use it when you want to:
- Calculate the number of hours, days, or minutes between two events.
- Measure how long ago a request or trace occurred relative to the current time.
- Compare event timestamps to detect delays or gaps in processing.
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, you typically calculate time differences using arithmetic on epoch timestamps, such as
eval diff=round((_time - relative_time(now(), "-1d@d")) / 3600). In APL, the datetime_diff function directly computes the difference between two datetime values in a specified unit.ANSI SQL users
ANSI SQL users
In ANSI SQL, you typically use
DATEDIFF(hour, start_time, end_time) or TIMESTAMPDIFF(HOUR, start_time, end_time) to compute the difference between timestamps. In APL, datetime_diff follows a similar pattern with the unit as the first argument.Usage
Syntax
Parameters
| Name | Type | Description |
|---|---|---|
| part | string | The unit for the result: 'year', 'quarter', 'month', 'week', 'day', 'hour', 'minute', 'second', 'millisecond', 'microsecond', 'nanosecond'. |
| datetime1 | datetime | The later datetime value (left side of subtraction). |
| datetime2 | datetime | The earlier datetime value (right side of subtraction). |
Returns
Along representing the number of periods of the specified unit in the result of datetime1 - datetime2.
Use case examples
- Log analysis
- OpenTelemetry traces
- Security logs
Calculate how many hours ago each request occurred.QueryRun in PlaygroundOutput
This query computes the number of hours between each request and the current time, giving you a quick sense of how recent each event is.
| _time | hours_ago | method | status |
|---|---|---|---|
| 2025-01-15T08:00:00Z | 26 | GET | 200 |
| 2025-01-15T09:30:00Z | 25 | POST | 201 |
| 2025-01-15T10:15:00Z | 24 | GET | 404 |
List of related functions
- datetime_add: Adds a specified number of date parts to a datetime. Use when you need to shift a timestamp rather than measure the gap between two.
- ago: Subtracts a timespan from the current UTC time. Use for simple relative time filters.
- now: Returns the current UTC time.
- todatetime: Converts a value to a datetime. Use to parse strings into datetime values before computing differences.