| transform(LogicalJoin) |  | 0% |  | 0% | 22 | 22 | 60 | 60 | 1 | 1 |
| expandSkewValueRows(Expression, List, Plan, int, DataType, StatementContext) |  | 0% |  | 0% | 5 | 5 | 43 | 43 | 1 | 1 |
| addNotNull(LogicalJoin, Expression, Set) |  | 0% |  | 0% | 6 | 6 | 21 | 21 | 1 | 1 |
| addRandomSlot(Expression, List, Plan, int, DataType, StatementContext) |  | 0% | | n/a | 1 | 1 | 11 | 11 | 1 | 1 |
| getIfCondition(Expression, List, List) |  | 0% |  | 0% | 9 | 9 | 14 | 14 | 1 | 1 |
| getSaltFactor() |  | 0% |  | 0% | 2 | 2 | 8 | 8 | 1 | 1 |
| getSaltedSkewValuesForSkewSide(Expression, Set, LogicalJoin) |  | 0% |  | 0% | 4 | 4 | 8 | 8 | 1 | 1 |
| getSaltedSkewValuesForExpandSide(Expression, Set) |  | 0% |  | 0% | 3 | 3 | 6 | 6 | 1 | 1 |
| lambda$getSaltedSkewValuesForSkewSide$5(Expression) |  | 0% |  | 0% | 2 | 2 | 1 | 1 | 1 | 1 |
| lambda$getSaltedSkewValuesForExpandSide$4(Expression) |  | 0% |  | 0% | 2 | 2 | 1 | 1 | 1 | 1 |
| lambda$addRandomSlot$3(Expression) |  | 0% |  | 0% | 2 | 2 | 1 | 1 | 1 | 1 |
| transform(MatchingContext) |  | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |
| lambda$build$2(LogicalJoin) |  | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |
| lambda$addNotNull$6(Expression) |  | 0% | | n/a | 1 | 1 | 1 | 1 | 1 | 1 |
| lambda$build$1(LogicalJoin) |  | 81% |   | 50% | 2 | 3 | 0 | 1 | 0 | 1 |
| build() |  | 100% | | n/a | 0 | 1 | 0 | 6 | 0 | 1 |
| lambda$build$0(LogicalJoin) |  | 100% |  | 100% | 0 | 3 | 0 | 1 | 0 | 1 |
| SaltJoin() |  | 100% | | n/a | 0 | 1 | 0 | 1 | 0 | 1 |