unixtime_milliseconds_todatetime converts a Unix timestamp that is expressed in whole milliseconds since 1970-01-01 00:00:00 UTC to an APL datetime value. Use the function whenever you ingest data that stores time as epoch milliseconds (for example, JSON logs from NGINX or metrics that follow the StatsD line protocol). Converting to datetime lets you bin, filter, and visualize events with the rest of your time-series 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.
unixtime_milliseconds_todatetime() corresponds to an eval expression that divides the epoch value by 1000 and formats the result. You skip both steps in APL because the function takes milliseconds directly.
| eval timestamp=strftime(epoch_ms/1000,"%Y-%m-%dT%H:%M:%SZ")
The function plays the same role as FROM_UNIXTIME() or TO_TIMESTAMP() in SQL dialects. In APL, you don’t divide by 1,000 because the function expects milliseconds.
SELECT FROM_UNIXTIME(epoch_ms/1000) AS timestamp FROM requests;

Usage

Syntax

unixtime_milliseconds_todatetime(milliseconds)

Parameters

NameTypeDescription
millisecondsint or longWhole milliseconds since the Unix epoch. Fractional input is truncated.

Returns

A datetime value that represents the given epoch milliseconds at UTC precision (1 millisecond).

Use case example

The HTTP access logs keep the timestamp as epoch milliseconds and you want to convert the values to datetime. Query
['sample-http-logs']
| extend epoch_milliseconds = toint(datetime_diff('Millisecond', _time, datetime(1970-01-01)))
| extend datetime_standard = unixtime_milliseconds_todatetime(epoch_milliseconds)
| project _time, epoch_milliseconds, datetime_standard
Run in Playground Output
_timeepoch_millisecondsdatetime_standard
May 15, 12:09:221,747,303,7622025-05-15T10:09:22Z
This query converts the timestamp to epoch milliseconds and then back to datetime for demonstration purposes.