The last
aggregate allows you to get the value of one column
as ordered by another. For example, last(temperature, time)
returns the
latest temperature value based on time within an aggregate group.
Important
The last
and first
commands do not use indexes, they perform a sequential scan through the group. They are primarily used for ordered selection within a GROUP BY
aggregate, and not as an alternative to an ORDER BY time DESC LIMIT 1
clause to find the latest value, which uses indexes.
Name | Type | Description |
---|---|---|
value | ANY ELEMENT | The value to return |
time | TIMESTAMP or INTEGER | The timestamp to use for comparison |
Get the temperature every 5 minutes for each device over the past day:
SELECT device_id, time_bucket('5 minutes', time) AS interval,last(temp, time)FROM metricsWHERE time > now () - INTERVAL '1 day'GROUP BY device_id, intervalORDER BY interval DESC;
This example uses first and last with an aggregate filter, and avoids null values in the output:
SELECTTIME_BUCKET('5 MIN', time_column) AS interv,AVG(temperature) as avg_temp,first(temperature,time_column) FILTER(WHERE time_column IS NOT NULL) AS beg_temp,last(temperature,time_column) FILTER(WHERE time_column IS NOT NULL) AS end_tempFROM sensorsGROUP BY interv
Keywords
Found an issue on this page?Report an issue or Edit this page in GitHub.