Skip to content

QueryBuilder🔗

Constructor🔗

new QueryBuilder()

Methods🔗

build🔗

Builds the object.

public Query build()

adhocFilters🔗

Additional Ad-hoc filters that take precedence over Scope on conflict.

public QueryBuilder adhocFilters(List<com.grafana.foundation.cog.Builder<AdhocFilters>> adhocFilters)

datasource🔗

New type for datasource reference

Not creating a new type until we figure out how to handle DS refs for group by, adhoc, and every place that uses DataSourceRef in TS.

public QueryBuilder datasource(com.grafana.foundation.cog.Builder<Dashboardv2beta1DataQueryKindDatasource> datasource)

editorMode🔗

what we should show in the editor

Possible enum values:

  • "builder"

  • "code"

public QueryBuilder editorMode(QueryEditorMode editorMode)

exemplar🔗

Execute an additional query to identify interesting raw samples relevant for the given expr

public QueryBuilder exemplar(Boolean exemplar)

expr🔗

The actual expression/query that will be evaluated by Prometheus

public QueryBuilder expr(String expr)

format🔗

The response format

Possible enum values:

  • "time_series"

  • "table"

  • "heatmap"

public QueryBuilder format(PromQueryFormat format)

groupByKeys🔗

Group By parameters to apply to aggregate expressions in the query

public QueryBuilder groupByKeys(List<String> groupByKeys)

hide🔗

true if query is disabled (ie should not be returned to the dashboard)

NOTE: this does not always imply that the query should not be executed since

the results from a hidden query may be used as the input to other queries (SSE etc)

public QueryBuilder hide(Boolean hide)

instant🔗

Returns only the latest value that Prometheus has scraped for the requested time series

public QueryBuilder instant()

interval🔗

An additional lower limit for the step parameter of the Prometheus query and for the

$__interval and $__rate_interval variables.

public QueryBuilder interval(String interval)

intervalFactor🔗

Used to specify how many times to divide max data points by. We use max data points under query options

See https://github.com/grafana/grafana/issues/48081

Deprecated: use interval

public QueryBuilder intervalFactor(Long intervalFactor)

intervalMs🔗

Interval is the suggested duration between time points in a time series query.

NOTE: the values for intervalMs is not saved in the query model. It is typically calculated

from the interval required to fill a pixels in the visualization

public QueryBuilder intervalMs(Double intervalMs)

labels🔗

public QueryBuilder labels(Map<String, String> labels)

legendFormat🔗

Series name override or template. Ex. {{hostname}} will be replaced with label value for hostname

public QueryBuilder legendFormat(String legendFormat)

maxDataPoints🔗

MaxDataPoints is the maximum number of data points that should be returned from a time series query.

NOTE: the values for maxDataPoints is not saved in the query model. It is typically calculated

from the number of pixels visible in a visualization

public QueryBuilder maxDataPoints(Long maxDataPoints)

queryType🔗

QueryType is an optional identifier for the type of query.

It can be used to distinguish different types of queries.

public QueryBuilder queryType(String queryType)

range🔗

Returns a Range vector, comprised of a set of time series containing a range of data points over time for each time series

public QueryBuilder range()

rangeAndInstant🔗

public QueryBuilder rangeAndInstant()

refId🔗

RefID is the unique identifier of the query, set by the frontend call.

public QueryBuilder refId(String refId)

resultAssertions🔗

Optionally define expected query result behavior

public QueryBuilder resultAssertions(com.grafana.foundation.cog.Builder<ResultAssertions> resultAssertions)

scopes🔗

A set of filters applied to apply to the query

public QueryBuilder scopes(List<com.grafana.foundation.cog.Builder<Scopes>> scopes)

timeRange🔗

TimeRange represents the query range

NOTE: unlike generic /ds/query, we can now send explicit time values in each query

NOTE: the values for timeRange are not saved in a dashboard, they are constructed on the fly

public QueryBuilder timeRange(com.grafana.foundation.cog.Builder<TimeRange> timeRange)

version🔗

public QueryBuilder version(String version)

See also🔗