Documentation

Fill null values in data

Use the fill() function to replace null values with:

data
    |> fill(usePrevious: true)

// OR

data
    |> fill(value: 0.0)

Fill empty windows of time

The fill() function does not fill empty windows of time. It only replaces null values in existing data. Filling empty windows of time requires time interpolation (see influxdata/flux#2428).

Fill with the previous value

To fill null values with the previous non-null value, set the usePrevious parameter to true.

Values remain null if there is no previous non-null value in the table.

data
    |> fill(usePrevious: true)

Given the following input:

_time_value
2020-01-01T00:01:00Znull
2020-01-01T00:02:00Z0.8
2020-01-01T00:03:00Znull
2020-01-01T00:04:00Znull
2020-01-01T00:05:00Z1.4

fill(usePrevious: true) returns:

_time_value
2020-01-01T00:01:00Znull
2020-01-01T00:02:00Z0.8
2020-01-01T00:03:00Z0.8
2020-01-01T00:04:00Z0.8
2020-01-01T00:05:00Z1.4

Fill with a specified value

To fill null values with a specified value, use the value parameter to specify the fill value. The fill value must match the data type of the column.

data
    |> fill(value: 0.0)

Given the following input:

_time_value
2020-01-01T00:01:00Znull
2020-01-01T00:02:00Z0.8
2020-01-01T00:03:00Znull
2020-01-01T00:04:00Znull
2020-01-01T00:05:00Z1.4

fill(value: 0.0) returns:

_time_value
2020-01-01T00:01:00Z0.0
2020-01-01T00:02:00Z0.8
2020-01-01T00:03:00Z0.0
2020-01-01T00:04:00Z0.0
2020-01-01T00:05:00Z1.4

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: