docs-v2/content/shared/influxdb-v2/query-data/influxql/explore-data/where.md

11 KiB

Use the WHERE clause to filter data based on fields, tags, and/or timestamps.

Syntax

SELECT_clause FROM_clause WHERE <conditional_expression> [(AND|OR) <conditional_expression> [...]]

The WHERE clause supports conditional_expressions on fields, tags, and timestamps.

{{% note %}} Note: InfluxDB does not support using OR in the WHERE clause to specify multiple time ranges. For example, InfluxDB returns an empty response for the following query:

SELECT * FROM "mydb" WHERE time = '2020-07-31T20:07:00Z' OR time = '2020-07-31T23:07:17Z'`

{{% /note %}}

Fields

field_key <operator> ['string' | boolean | float | integer]

The WHERE clause supports comparisons against string, boolean, float, and integer field values.

Single quote string field values in the WHERE clause. Queries with unquoted string field values or double quoted string field values will not return any data and, in most cases, will not return an error.

Supported operators

Operator Meaning
= equal to
<> not equal to
!= not equal to
> greater than
>= greater than or equal to
< less than
<= less than or equal to

InfluxQL also supports Regular Expressions.

Tags

tag_key <operator> ['tag_value']

Single quote tag values in the WHERE clause. Queries with unquoted tag values or double quoted tag values will not return any data and, in most cases, will not return an error.

Supported operators

Operator Meaning
= equal to
<> not equal to
!= not equal to

Timestamps

For most SELECT statements, the default time range is between 1677-09-21 00:12:43.145224194 and 2262-04-11T23:47:16.854775806Z UTC. For SELECT statements with a GROUP BY time() clause, the default time range is between 1677-09-21 00:12:43.145224194 UTC and now().

See Time Syntax for information on how to specify alternative time ranges in the WHERE clause.

Examples

{{< expand-wrapper >}} {{% expand "Select data with specific field key-values" %}}

SELECT * FROM "h2o_feet" WHERE "water_level" > 9

Output: {{% influxql/table-meta %}} Name: h2o_feet {{% /influxql/table-meta %}}

time level description location water_level
2019-08-25T04:00:00Z at or greater than 9 feet coyote_creek 9.0320000000
2019-08-25T04:06:00Z at or greater than 9 feet coyote_creek 9.0780000000
2019-08-25T04:12:00Z at or greater than 9 feet coyote_creek 9.1110000000
2019-08-25T04:18:00Z at or greater than 9 feet coyote_creek 9.1500000000
2019-08-25T04:24:00Z at or greater than 9 feet coyote_creek 9.1800000000

The query returns data from the h2o_feet measurement with field values of water_level that are greater than nine. This is a partial data set.

{{% /expand %}}

{{% expand "Select data with a specific string field key-value" %}}

SELECT * FROM "h2o_feet" WHERE "level description" = 'below 3 feet'

Output: {{% influxql/table-meta %}} Name: h2o_feet {{% /influxql/table-meta %}}

time level description location water_level
2019-08-17T00:00:00Z below 3 feet santa_monica 2.0640000000
2019-08-17T00:06:00Z below 3 feet santa_monica 2.1160000000
2019-08-17T00:12:00Z below 3 feet santa_monica 2.0280000000
2019-08-17T00:18:00Z below 3 feet santa_monica 2.1260000000
2019-08-17T00:24:00Z below 3 feet santa_monica 2.0410000000
2019-08-17T00:30:00Z below 3 feet santa_monica 2.0510000000

The query returns data from the h2o_feet measurement with field values of level description that equal the below 3 feet string. InfluxQL requires single quotes around string field values in the WHERE clause.

{{% /expand %}}

{{% expand "Select data with a specific field key-value and perform basic arithmetic" %}}

SELECT * FROM "h2o_feet" WHERE "water_level" + 2 > 11.9

Output: {{% influxql/table-meta %}} Name: h2o_feet {{% /influxql/table-meta %}}

time level description location water_level
2019-08-28T07:06:00Z at or greater than 9 feet coyote_creek 9.9020000000
2019-08-28T07:12:00Z at or greater than 9 feet coyote_creek 9.9380000000
2019-08-28T07:18:00Z at or greater than 9 feet coyote_creek 9.9570000000
2019-08-28T07:24:00Z at or greater than 9 feet coyote_creek 9.9640000000
2019-08-28T07:30:00Z at or greater than 9 feet coyote_creek 9.9540000000
2019-08-28T07:36:00Z at or greater than 9 feet coyote_creek 9.9410000000
2019-08-28T07:42:00Z at or greater than 9 feet coyote_creek 9.9250000000
2019-08-28T07:48:00Z at or greater than 9 feet coyote_creek 9.9020000000
2019-09-01T23:30:00Z at or greater than 9 feet coyote_creek 9.9020000000

The query returns data from the h2o_feet measurement with field values of water_level plus two that are greater than 11.9. Note that InfluxDB follows the standard order of operations.

See Mathematical operators for more on supported operators.

{{% /expand %}}

{{% expand "Select data with a specific tag key-value" %}}

SELECT "water_level" FROM "h2o_feet" WHERE "location" = 'santa_monica'

Output: {{% influxql/table-meta %}} Name: h2o_feet {{% /influxql/table-meta %}}

time water_level
2019-08-17T00:00:00Z 2.0640000000
2019-08-17T00:06:00Z 2.1160000000
2019-08-17T00:12:00Z 2.0280000000
2019-08-17T00:18:00Z 2.1260000000
2019-08-17T00:24:00Z 2.0410000000

The query returns data from the h2o_feet measurement where the tag key location is set to santa_monica. InfluxQL requires single quotes around tag values in the WHERE clause.

{{% /expand %}}

{{% expand "Select data with specific field key-values and tag key-valuest" %}}

SELECT "water_level" FROM "h2o_feet" WHERE "location" <> 'santa_monica' AND (water_level < -0.59 OR water_level > 9.95)

Output: {{% influxql/table-meta %}} Name: h2o_feet {{% /influxql/table-meta %}}

time water_level
2019-08-28T07:18:00Z 9.9570000000
2019-08-28T07:24:00Z 9.9640000000
2019-08-28T07:30:00Z 9.9540000000
2019-08-28T14:30:00Z -0.6100000000
2019-08-28T14:36:00Z -0.5910000000
2019-08-29T15:18:00Z -0.5940000000

The query returns data from the h2o_feet measurement where the tag key location is not set to santa_monica and where the field values of water_level are either less than -0.59 or greater than 9.95. The WHERE clause supports the operators AND and OR, and supports separating logic with parentheses.

{{% /expand %}}

{{< /expand-wrapper >}}

SELECT * FROM "h2o_feet" WHERE time > now() - 7d

The query returns data from the h2o_feet measurement with timestamps within the past seven days. See Time Syntax for more in-depth information on supported time syntax in the WHERE clause.

Common issues with the WHERE clause

A WHERE clause query unexpectedly returns no data

In most cases, this issue is the result of missing single quotes around tag values or string field values. Queries with unquoted or double quoted tag values or string field values will not return any data and, in most cases, will not return an error.

The first two queries in the code block below attempt to specify the tag value santa_monica without any quotes and with double quotes. Those queries return no results. The third query single quotes santa_monica (this is the supported syntax) and returns the expected results.

SELECT "water_level" FROM "h2o_feet" WHERE "location" = santa_monica
No results

SELECT "water_level" FROM "h2o_feet" WHERE "location" = "santa_monica"
No results

SELECT "water_level" FROM "h2o_feet" WHERE "location" = 'santa_monica'

Output: {{% influxql/table-meta %}} Name: h2o_feet {{% /influxql/table-meta %}}

time water_level
2019-08-17T00:00:00Z 2.0640000000
2019-08-17T00:06:00Z 2.1160000000
2019-08-17T00:12:00Z 2.0280000000
2019-08-17T00:18:00Z 2.1260000000
2019-08-17T00:24:00Z 2.0410000000
2019-08-17T00:30:00Z 2.0510000000

The first two queries in the code block below attempt to specify the string field value at or greater than 9 feet without any quotes and with double quotes. The first query returns an error because the string field value includes white spaces. The second query returns no results. The third query single quotes at or greater than 9 feet (this is the supported syntax) and returns the expected results.

SELECT "level description" FROM "h2o_feet" WHERE "level description" = at or greater than 9 feet
ERR: 400 Bad Request: failed to parse query: found than, expected ; at line 1, char 86

SELECT "level description" FROM "h2o_feet" WHERE "level description" = "at or greater than 9 feet"
No results

SELECT "level description" FROM "h2o_feet" WHERE "level description" = 'at or greater than 9 feet'

Output: {{% influxql/table-meta %}} Name: h2o_feet {{% /influxql/table-meta %}}

time level_description
2019-08-25T04:00:00Z at or greater than 9 feet
2019-08-25T04:06:00Z at or greater than 9 feet
019-08-25T04:12:00Z at or greater than 9 feet
2019-08-25T04:18:00Z at or greater than 9 feet
2019-08-25T04:24:00Z at or greater than 9 feet