Skip to main content

UnPivot

Creates multiple records from sets of columns. It offers a way to consolidate columns by exploding records.

Before UnPivot:

idscore_item1score_item2score_item3
1001452
10026010

After UnPivot:

iditemscore
100114
100125
100132
100216
100220
1002310

Example syntax

{
stack: [
{ id: "id", item: "1", score: "score_item1" },
{ id: "id", item: "2", score: "score_item2" },
{ id: "id", item: "3", score: "score_item3" },
]
}

Stack

Stack is an array of stack entries. At least 2 stack entries should exist. Each stack entry is a JSON object that contains field assignment(s). This defines the column consolidation (the unpivot), as each stack entry can assign a unique column to a consolidated column name.

stack: [
{ brand: "1", score: "score_b1" }, // assigns score_b1 into q1 (also adds a brand id of 1)
{ brand: "2", score: "score_b2" }, // assigns score_b2 into q1 (also adds a brand id of 2)
{ brand: "3", score: "score_b3" }, // assigns score_b2 into q1 (also adds a brand id of 2)
]

A stack entry field assignment can be an expression

stack: [
{ brand: "1", score: "score_b1 * 100" },
{ brand: "2", score: "score_b2 * 100" },
{ brand: "3", score: "score_b3 * 100" },
]

Keep

Keep is optional. It is a convenient way to add expression(s) to every stack entry. You might use it if you have a long list of variables to keep and don't want to redundantly type them for every stack entry. Keep expressions provide the same value for every stack entry.

// using "keep"
{
keep: {
// (rob todo: consider a simplified array syntax)
id: "id",
q2: "q2 * 100", // it can be an expression
q3: "q3",
q4: "q4"
},
stack: [
{ brand: "1", score: "score_b1" },
{ brand: "2", score: "score_b2" },
{ brand: "3", score: "score_b3" },
]
}

// equivalent syntax without using "keep"
{
stack: [
{ id: "id", brand: "1", score: "score_b1", q2: "q2 * 100", q3: "q3", q4: "q4" },
{ id: "id", brand: "2", score: "score_b2", q2: "q2 * 100", q3: "q3", q4: "q4" },
{ id: "id", brand: "3", score: "score_b3", q2: "q2 * 100", q3: "q3", q4: "q4" },
]
}

Meta

Todo - I should probably add a way to add field meta, so one could add e.g., brand labels to a single numeric var brand. User could do it later in an addFields stage, but it probably wouldn't hurt to add it here.

{
keep: ...,
stack: ...,
meta: {
"brand": {
"label": "Brand",
"valueLabels": [
{ "value": 1, "label": "Acme" },
{ "value": 2, "label": "NSP" },
...
{ "value": 99, "label": "Netherbrand" }
]
}
}
}

Other:

note

You might want to append a filter stage after this stage to remove empty entries. (Or should I integrate it somehow?)


// unpivot stage
{
keep: {
"id": "id"
},
stack: [
{ brand: "1", score: "score_b1" }, // assigns score_b1 into score (also adds a brand id of 1)
{ brand: "2", score: "score_b2" }, // assigns score_b2 into score (also adds a brand id of 2)
],
filter: [
"score is not null" // ??
]
}

// filter stage
["score is not null"]