Documentation

Regular expressions

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

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.

/regular_expression/
  • Copy
  • Fill window

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 (?).

/(?iU)foo*/
  • Copy
  • Fill window

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:

Use a regular expression to specify field keys and tag keys in the SELECT clause

Use a regular expression to specify measurements in the FROM clause

Use a regular expression to specify tag values in the WHERE clause

Use a regular expression to specify a tag with no value in the WHERE clause

Use a regular expression to specify tag keys in the GROUP BY clause


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 Core and Enterprise are now in Beta

InfluxDB 3 Core and Enterprise are now available for beta testing, available under MIT or Apache 2 license.

InfluxDB 3 Core is a high-speed, recent-data engine that collects and processes data in real-time, while persisting it to local disk or object storage. InfluxDB 3 Enterprise is a commercial product that builds on Core’s foundation, adding high availability, read replicas, enhanced security, and data compaction for faster queries. A free tier of InfluxDB 3 Enterprise will also be available for at-home, non-commercial use for hobbyists to get the full historical time series database set of capabilities.

For more information, check out: