Documentation

Group geo-temporal data

This page documents an earlier version of InfluxDB OSS. InfluxDB OSS v2 is the latest stable version. See the equivalent InfluxDB v2 documentation: Group geo-temporal data.

Use the geo.groupByArea() to group geo-temporal data by area and geo.asTracks() to group data into tracks or routes.

Group data by area

Use the geo.groupByArea() function to group geo-temporal data points by geographic area. Areas are determined by S2 grid cells

  • Specify a new column to store the unique area identifier for each point with the newColumn parameter.
  • Specify the S2 cell level to use when calculating geographic areas with the level parameter.

The following example uses the sample bird migration data to query data points within 200km of Cairo, Egypt and group them by geographic area:

import "experimental/geo"

sampleGeoData
  |> geo.filterRows(region: {lat: 30.04, lon: 31.23, radius: 200.0})
  |> geo.groupByArea(
    newColumn: "geoArea",
    level: 5
  )

Group data by track or route

Use geo.asTracks() function to group data points into tracks or routes and order them by time or other columns. Data must contain a unique identifier for each track. For example: id or tid.

  • Specify columns that uniquely identify each track or route with the groupBy parameter.
  • Specify which columns to sort by with the orderBy parameter. Default is ["_time"].

The following example uses the sample bird migration data to query data points within 200km of Cairo, Egypt and group them into routes unique to each bird:

import "experimental/geo"

sampleGeoData
  |> geo.filterRows(region: {lat: 30.04, lon: 31.23, radius: 200.0})
  |> geo.asTracks(
    groupBy: ["id"],
    orderBy: ["_time"]
  )

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: