pivot() function
pivot() collects unique values stored vertically (column-wise) and aligns them
horizontally (row-wise) into logical sets.
Output data
The group key of the resulting table is the same as the input tables,
excluding columns found in the columnKey and valueColumn parameters.
These columns are not part of the resulting output table and are dropped from
the group key.
Every input row should have a 1:1 mapping to a particular row and column
combination in the output table. Row and column combinations are determined
by the rowKey and columnKey parameters. In cases where more than one
value is identified for the same row and column pair, the last value
encountered in the set of table rows is used as the result.
The output is constructed as follows:
- The set of columns for the new table is the
rowKeyunioned with the group key, but excluding the columns indicated by thecolumnKeyand thevalueColumn. - A new column is added to the set of columns for each unique value
identified by the
columnKeyparameter. - The label of a new column is the concatenation of the values of
columnKeyusing_as a separator. If the value is null, “null” is used. - A new row is created for each unique value identified by the
rowKeyparameter. - For each new row, values for group key columns stay the same, while values
for new columns are determined from the input tables by the value in
valueColumnat the row identified by therowKeyvalues and the new column’s label. If no value is found, the value is set tonull. - Any column that is not part of the group key or not specified in the
rowKey,columnKey, andvalueColumnparameters is dropped.
Function type signature
(<-tables: stream[A], columnKey: [string], rowKey: [string], valueColumn: string) => stream[B] where A: Record, B: RecordFor more information, see Function type signatures.
Parameters
rowKey
(Required) Columns to use to uniquely identify an output row.
columnKey
(Required) Columns to use to identify new output columns.
valueColumn
(Required)
Column to use to populate the value of pivoted columnKey columns.
tables
Input data. Default is piped-forward data (<-).
Examples
Align fields into rows based on time
data
|> pivot(rowKey: ["_time"], columnKey: ["_field"], valueColumn: "_value")Associate values to tags by time
import "sampledata"
sampledata.int()
|> pivot(rowKey: ["_time"], columnKey: ["tag"], valueColumn: "_value")Was this page helpful?
Thank you for your feedback!
Support and feedback
Thank you for being part of our community! We welcome and encourage your feedback and bug reports for Flux and this documentation. To find support, use the following resources:
Customers with an annual or support contract can contact InfluxData Support.