Back to Influxdb

Regular Expressions

content/shared/influxql-v3-reference/regular-expressions.md

latest7.3 KB
Original Source

Regular expressions are a sequence of characters used to identify patterns in identifiers and string values. InfluxQL supports regular expressions in the following operations:

[!Important]

Query performance

Regular expression comparisons are more computationally intensive than exact string comparisons. Queries with regular expressions are not as performant as those without.

Regular expression syntax

InfluxQL Regular expressions are surrounded by / characters and use the Go regular expression syntax.

sql
/regular_expression/

Regular expression flags

Regular expression flags modify the pattern-matching behavior of the expression. InfluxQL supports the following regular expression flags:

FlagDescription
icase-insensitive
mmulti-line mode: ^ and $ match begin/end line in addition to begin/end text
slet . match \n
Uungreedy: swap meaning of x* and x*?, x+ and x+?, etc.

Include regular expression flags at the beginning of your regular expression pattern enclosed in parentheses (()) and preceded by a question mark (?).

sql
/(?iU)foo*/

Regular expression operators

InfluxQL provides the following regular expression operators that test if a string operand matches a regular expression:

  • =~: Returns true if the string matches the regular expression
  • !~: Returns true if the string does not match the regular expression

InfluxQL regular expression operators are used to test string column values in the WHERE clause.

Regular expression examples

The examples below use the following sample data sets:

{{< expand-wrapper >}}

{{% expand "Use a regular expression to specify field keys and tag keys in the SELECT clause" %}}

sql
SELECT /^t/ FROM weather

{{% influxql/table-meta %}} name: weather {{% /influxql/table-meta %}}

timetemp_avgtemp_maxtemp_min
2020-01-01T00:00:00Z526644
2020-01-01T00:00:00Z535947
2020-01-01T00:00:00Z505744
2020-01-02T00:00:00Z546149
2020-01-02T00:00:00Z516044
2020-01-02T00:00:00Z536642
............

{{% /expand %}}

{{% expand "Use a regular expression to specify measurements in the FROM clause" %}}

sql
SELECT /^t/ FROM /^[hw]/

{{% influxql/table-meta %}} name: weather {{% /influxql/table-meta %}}

timetemptemp_avgtemp_maxtemp_min
2020-01-01T00:00:00Z526644
2020-01-01T00:00:00Z535947
2020-01-01T00:00:00Z505744
2020-01-02T00:00:00Z546149
2020-01-02T00:00:00Z516044
2020-01-02T00:00:00Z536642
...............

{{% /expand %}}

{{% expand "Use a regular expression to specify tag values in the WHERE clause" %}}

sql
SELECT * FROM weather WHERE location !~ /^[S]/

{{% influxql/table-meta %}} name: weather {{% /influxql/table-meta %}}

timelocationpreciptemp_avgtemp_maxtemp_minwind_avg
2020-01-01T00:00:00ZConcord05266443.13
2020-01-01T00:00:00ZHayward05057442.24
2020-01-02T00:00:00ZConcord05366423.13
2020-01-02T00:00:00ZHayward05160443.8
2020-01-03T00:00:00ZConcord04960382.68
2020-01-03T00:00:00ZHayward05062413.13
.....................

{{% /expand %}}

{{% expand "Use a regular expression to specify a tag with no value in the WHERE clause" %}}

sql
SELECT * FROM home, weather WHERE location !~ /./

{{% influxql/table-meta %}} name: weather {{% /influxql/table-meta %}}

timecohumlocationpreciproomtemptemp_avgtemp_maxtemp_minwind_avg
2022-01-01T08:00:00Z035.9Kitchen21
2022-01-01T08:00:00Z035.9Living Room21.1
2022-01-01T09:00:00Z036.2Kitchen23
2022-01-01T09:00:00Z035.9Living Room21.4
2022-01-01T10:00:00Z036.1Kitchen22.7
2022-01-01T10:00:00Z036Living Room21.8
.................................

{{% /expand %}}

{{% expand "Use a regular expression to specify tag keys in the GROUP BY clause" %}}

sql
SELECT MAX(precip) FROM weather GROUP BY /^l/

{{% influxql/table-meta %}} name: weather
tags: location=Concord {{% /influxql/table-meta %}}

timemax
2021-10-24T00:00:00Z4.53

{{% influxql/table-meta %}} name: weather
tags: location=Hayward {{% /influxql/table-meta %}}

timemax
2022-12-31T00:00:00Z4.34

{{% influxql/table-meta %}} name: weather
tags: location=San Francisco {{% /influxql/table-meta %}}

timemax
2021-10-24T00:00:00Z4.02

{{% /expand %}}

{{< /expand-wrapper >}}