Virtual columns

    Virtual columns are queryable column “views” created from a set of columns during a query.

    A virtual column can potentially draw from multiple underlying columns, although a virtual column always presents itself as a single column.

    Virtual columns can be referenced by their output names to be used as dimensions or as inputs to and aggregators.

    Expression virtual columns use Druid’s native system to allow defining query time transforms of inputs from one or more columns.

    The expression virtual column has the following syntax:

    1. "type": "expression",
    2. "name": <name of the virtual column>,
    3. "outputType": <output value type of expression>
    4. }

    The nested field virtual column is an optimized virtual column that can provide direct access into various paths of a COMPLEX<json> column, including using their indexes.

    You can define a nested field virtual column with any of the following equivalent syntaxes. The examples all produce the same output value, with each example showing a different way to specify how to access the nested value. The first is using JSONPath syntax path, the second with a jq path, and the third uses pathParts.

    1. {
    2. "type": "nested-field",
    3. "columnName": "shipTo",
    4. "outputName": "v1",
    5. "path": ".phoneNumbers[1].number",
    6. }

    Nested path part

    Specify pathParts as an array of objects that describe each component of the path to traverse. Each object can take the following properties:

    See Nested columns for more information on ingesting and storing nested data.

    1. {
    2. "type": "mv-filtered",
    3. "name": "filteredDim3",
    4. "delegate": "dim3",
    5. "values": ["hello", "world"],
    6. "isAllowList": true
    7. }