---
title: Fill null values in data
seotitle: Fill null values in data
list_title: Fill
description: >
Use `fill()` function to replace _null_ values.
weight: 210
menu:
influxdb_2_1:
parent: Query with Flux
name: Fill
influxdb/v2.1/tags: [query, fill]
related:
- /{{< latest "flux" >}}/stdlib/universe/fill/
list_query_example: fill_null
Use [`fill()`](/{{< latest "flux" >}}/stdlib/universe/fill/)
to replace _null_ values with:
- [the previous non-null value](#fill-with-the-previous-value)
- [a specified value](#fill-with-a-specified-value)
<!-- -->
```js
data
|> fill(usePrevious: true)
// OR
|> fill(value: 0.0)
```
{{% note %}}
#### 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](https://github.com/influxdata/flux/issues/2428))_.
{{% /note %}}
## 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.
{{< flex >}}
{{% flex-content %}}
**Given the following input:**
| _time | _value |
|:----- | ------:|
| 2020-01-01T00:01:00Z | null |
| 2020-01-01T00:02:00Z | 0.8 |
| 2020-01-01T00:03:00Z | null |
| 2020-01-01T00:04:00Z | null |
| 2020-01-01T00:05:00Z | 1.4 |
{{% /flex-content %}}
**`fill(usePrevious: true)` returns:**
| 2020-01-01T00:03:00Z | 0.8 |
| 2020-01-01T00:04:00Z | 0.8 |
{{< /flex >}}
## 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](/{{< latest "flux" >}}/spec/types/#basic-types)
of the [column](/{{< latest "flux" >}}/stdlib/universe/fill/#column)._
**`fill(value: 0.0)` returns:**
| 2020-01-01T00:01:00Z | 0.0 |
| 2020-01-01T00:03:00Z | 0.0 |
| 2020-01-01T00:04:00Z | 0.0 |