Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ public class JoinReorderContext {
private boolean hasLeftAssociate = false;

private boolean isLeadingJoin = false;
private boolean isSaltJoinGenerated = false;

public JoinReorderContext() {
}
Expand All @@ -55,6 +56,7 @@ public void copyFrom(JoinReorderContext joinReorderContext) {
this.hasRightAssociate = joinReorderContext.hasRightAssociate;
this.hasCommuteZigZag = joinReorderContext.hasCommuteZigZag;
this.isLeadingJoin = joinReorderContext.isLeadingJoin;
this.isSaltJoinGenerated = joinReorderContext.isSaltJoinGenerated;
}

/**
Expand All @@ -68,6 +70,7 @@ public void clear() {
hasRightAssociate = false;
hasLeftAssociate = false;
isLeadingJoin = false;
isSaltJoinGenerated = false;
}

public boolean hasCommute() {
Expand Down Expand Up @@ -125,4 +128,12 @@ public boolean isLeadingJoin() {
public void setLeadingJoin(boolean leadingJoin) {
isLeadingJoin = leadingJoin;
}

public boolean isSaltJoinGenerated() {
return isSaltJoinGenerated;
}

public void setSaltJoinGenerated(boolean saltJoinGenerated) {
isSaltJoinGenerated = saltJoinGenerated;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -325,6 +325,7 @@ private static LogicalProject<Plan> expandSkewValueRows(Expression skewExpr, Lis
equalTo = (EqualPredicate) TypeCoercionUtils.processComparisonPredicate(equalTo);
JoinReorderContext joinReorderContext = new JoinReorderContext();
joinReorderContext.setLeadingJoin(true);
joinReorderContext.setSaltJoinGenerated(true);
LogicalJoin<Plan, Plan> rightJoin = new LogicalJoin<>(JoinType.RIGHT_OUTER_JOIN, ImmutableList.of(equalTo),
project, originPlan, joinReorderContext);
// construct upper project
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -54,8 +54,9 @@ public class SkewJoin extends OneRewriteRuleFactory {
public Rule build() {
return logicalJoin()
.when(join -> join.getJoinType().isOneSideOuterJoin()
|| join.getJoinType().isInnerJoin() || join.getJoinType().isAsofJoin())
|| join.getJoinType().isInnerJoin())
.when(join -> join.getDistributeHint().distributeType == DistributeType.NONE)
.whenNot(join -> join.getJoinReorderContext().isSaltJoinGenerated())
.whenNot(LogicalJoin::isMarkJoin)
.thenApply(SkewJoin::transform).toRule(RuleType.SALT_JOIN);
}
Expand Down Expand Up @@ -86,8 +87,7 @@ private static Plan transform(MatchingContext<LogicalJoin<Plan, Plan>> ctx) {
equal = equal.commute();
}

if (join.getJoinType().isInnerJoin() || join.getJoinType().isLeftOuterJoin()
|| join.getJoinType().isAsofInnerJoin() || join.getJoinType().isAsofLeftOuterJoin()) {
if (join.getJoinType().isInnerJoin() || join.getJoinType().isLeftOuterJoin()) {
Expression leftEqHand = equal.child(0);
if (left.getStats().findColumnStatistics(leftEqHand) != null) {
ColumnStatistic leftColStats = left.getStats().findColumnStatistics(leftEqHand);
Expand All @@ -98,7 +98,7 @@ private static Plan transform(MatchingContext<LogicalJoin<Plan, Plan>> ctx) {
hotValues.addAll(filtered.keySet());
}
}
} else if (join.getJoinType().isRightOuterJoin() || join.getJoinType().isAsofRightOuterJoin()) {
} else if (join.getJoinType().isRightOuterJoin()) {
Expression rightEqHand = equal.child(1);
if (right.getStats().findColumnStatistics(rightEqHand) != null) {
ColumnStatistic rightColStats = right.getStats().findColumnStatistics(rightEqHand);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -136,11 +136,14 @@ public void testRightJoin() {
logicalGenerate(
logicalUnion())),
logicalOlapScan()
).when(join -> join.getJoinType() == JoinType.RIGHT_OUTER_JOIN)
).when(join -> join.getJoinType() == JoinType.RIGHT_OUTER_JOIN
&& join.getJoinReorderContext().isSaltJoinGenerated())
),
logicalProject(
logicalOlapScan())
).when(join -> join.getHashJoinConjuncts().size() == 2 && join.getJoinType() == JoinType.RIGHT_OUTER_JOIN)
).when(join -> join.getHashJoinConjuncts().size() == 2
&& join.getJoinType() == JoinType.RIGHT_OUTER_JOIN
&& !join.getJoinReorderContext().isSaltJoinGenerated())
);
}

Expand Down Expand Up @@ -265,11 +268,14 @@ public void testLeading() {
logicalGenerate(
logicalUnion())),
logicalOlapScan()
).when(join -> join.getJoinType() == JoinType.RIGHT_OUTER_JOIN)
).when(join -> join.getJoinType() == JoinType.RIGHT_OUTER_JOIN
&& join.getJoinReorderContext().isSaltJoinGenerated())
),
logicalProject(
logicalOlapScan())
).when(join -> join.getHashJoinConjuncts().size() == 2 && join.getJoinType() == JoinType.RIGHT_OUTER_JOIN)
).when(join -> join.getHashJoinConjuncts().size() == 2
&& join.getJoinType() == JoinType.RIGHT_OUTER_JOIN
&& !join.getJoinReorderContext().isSaltJoinGenerated())
);
}

Expand Down
Loading