Documentation

Aggregate data with InfluxQL

InfluxDB 3 Core is in Public Alpha

InfluxDB 3 Core is in public alpha and available for testing and feedback, but is not meant for production use. Both the product and this documentation are works in progress. We welcome and encourage your input about your experience with the alpha and invite you to join our public channels for updates and to share feedback.

Alpha expectations and recommendations

An InfluxQL query that aggregates data includes the following clauses:

* Required
  • * SELECT: Specify fields and calculations to output from a measurement or use the wildcard alias (*) to select all fields and tags from a measurement.
  • * FROM: Specify the measurement to query data from.
  • WHERE: Only retrieve data that meets the specified conditions–for example, time is in a time range, contains specific tag values, or contains a field value outside specified thresholds.
  • GROUP BY: Group data by tag values and time intervals.

For simplicity, the term “aggregate” in this guide refers to applying both aggregate and selector functions to a dataset.

Learn how to apply aggregate operations to your queried data:

InfluxDB v1 to InfluxDB 3 data model

InfluxQL was designed around the InfluxDB v1 data model, but can still be used to query data from InfluxDB 3 Core. When using the InfluxDB 3 Core InfluxQL implementation, the data model is different in the following ways:

  • an InfluxDB v1 database and retention policy combination is combined into a single InfluxDB 3 database entity.
  • an InfluxDB v1 measurement is equivalent to an InfluxDB 3 table.

Aggregate and selector functions

Both aggregate and selector functions return a limited number of rows from each group. Aggregate functions return a single row, whereas some selector functions let you specify the number of rows to return from each group. For example, if you GROUP BY room and perform an aggregate operation in your SELECT clause, results include an aggregate value for each unique value of room.

Aggregate functions

Use aggregate functions to aggregate values in a specified field for each group and return a single row per group containing the aggregate field value.

View InfluxQL aggregate functions

Basic aggregate query
SELECT MEAN(co) from home

Selector functions

Use selector functions to “select” a value from a specified field.

View InfluxQL selector functions

Basic selector query
SELECT TOP(co, 3) from home

Example aggregate queries

Sample data

The following examples use the Home sensor data. To run the example queries and return results, write the sample data to your InfluxDB 3 Core database before running the example queries.

Perform an ungrouped aggregation

To aggregate all queried values in a specified field:

  • Use aggregate or selector functions in your SELECT statement.
  • Do not include a GROUP BY clause to leave your data ungrouped.
SELECT MEAN(co) AS "average co" FROM home

View example results

Group and aggregate data

To apply aggregate or selector functions to grouped data:

  • Use aggregate or selector functions in your SELECT statement.
  • Include a GROUP BY clause with a comma-delimited list of tags to group by.

Keep the following in mind when using GROUP BY:

  • GROUP BY can use column aliases that are defined in the SELECT clause.
SELECT
  MEAN(temp) AS "average temp"
FROM home
GROUP BY room

View example results

Downsample data by applying interval-based aggregates

A common use case when querying time series is downsampling data by applying aggregates to time-based groups. To group and aggregate data into time-based groups:

  • In your SELECT clause, apply aggregate or selector functions to queried fields.

  • In your WHERE clause, include time bounds for the query. Interval-based aggregates produce a row for each specified time interval. If no time bounds are specified in the WHERE clause, the query uses the default time range (1970-01-01T00:00:00Z to now) and returns a row for each interval in that time range.

  • In your GROUP BY clause:

    • Use the time() function to specify the time interval to group by.
    • Optional: Specify other tags to group by.

The following example retrieves unique combinations of time intervals and rooms with their minimum, maximum, and average temperatures.

SELECT
  MAX(temp) AS "max temp",
  MIN(temp) AS "min temp",
  MEAN(temp) AS "average temp"
FROM home
WHERE
  time >= '2022-01-01T08:00:00Z'
  AND time < '2022-01-01T20:00:00Z'
GROUP BY time(2h), room

View example results


Was this page helpful?

Thank you for your feedback!


The future of Flux

Flux is going into maintenance mode. You can continue using it as you currently are without any changes to your code.

Read more

InfluxDB 3 Open Source Now in Public Alpha

InfluxDB 3 Open Source is now available for alpha testing, licensed under MIT or Apache 2 licensing.

We are releasing two products as part of the alpha.

InfluxDB 3 Core, is our new open source product. It is a recent-data engine for time series and event data. InfluxDB 3 Enterprise is a commercial version that builds on Core’s foundation, adding historical query capability, read replicas, high availability, scalability, and fine-grained security.

For more information on how to get started, check out: