Datasources

A data source is the Apache Druid equivalent of a database table. However, a query can also masquerade as a data source, providing subquery-like functionality. Query data sources are currently supported only by GroupBy queries.

Table datasource

The table data source is the most common type. It’s represented by a string, or by the full structure:

  1. {
  2. "type": "table",
  3. "name": "<string_value>"
  4. }

Union datasource

This data source unions two or more table data sources.

  1. {
  2. "type": "union",
  3. "dataSources": ["<string_value1>", "<string_value2>", "<string_value3>", ... ]
  4. }

Note that the data sources being unioned should have the same schema. Union Queries should be always sent to a Broker/Router process and are NOT supported directly by the Historical processes.

Query datasource

This is used for nested groupBys and is only currently supported for groupBys.

  1. {
  2. "type": "query",
  3. "query": {
  4. "type": "groupBy",
  5. ...
  6. }
  7. }