All Downloads are FREE. Search and download functionalities are using the official Maven repository.
Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
io.trino.operator.join.LookupJoinOperatorFactory Maven / Gradle / Ivy
/*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.trino.operator.join;
import com.google.common.collect.ImmutableList;
import com.google.common.primitives.Ints;
import io.trino.operator.HashGenerator;
import io.trino.operator.JoinOperatorType;
import io.trino.operator.OperatorFactory;
import io.trino.operator.PrecomputedHashGenerator;
import io.trino.operator.ProcessorContext;
import io.trino.operator.WorkProcessor;
import io.trino.operator.WorkProcessorOperator;
import io.trino.operator.WorkProcessorOperatorFactory;
import io.trino.operator.join.JoinProbe.JoinProbeFactory;
import io.trino.operator.join.LookupOuterOperator.LookupOuterOperatorFactory;
import io.trino.spi.Page;
import io.trino.spi.type.Type;
import io.trino.spi.type.TypeOperators;
import io.trino.spiller.PartitioningSpillerFactory;
import io.trino.sql.planner.plan.PlanNodeId;
import java.util.List;
import java.util.Optional;
import java.util.OptionalInt;
import static com.google.common.base.Preconditions.checkArgument;
import static com.google.common.base.Preconditions.checkState;
import static com.google.common.collect.ImmutableList.toImmutableList;
import static io.trino.operator.InterpretedHashGenerator.createChannelsHashGenerator;
import static io.trino.operator.join.LookupJoinOperatorFactory.JoinType.INNER;
import static io.trino.operator.join.LookupJoinOperatorFactory.JoinType.PROBE_OUTER;
import static java.util.Objects.requireNonNull;
public class LookupJoinOperatorFactory
implements JoinOperatorFactory, WorkProcessorOperatorFactory
{
public enum JoinType
{
INNER,
PROBE_OUTER, // the Probe is the outer side of the join
LOOKUP_OUTER, // The LookupSource is the outer side of the join
FULL_OUTER,
}
private final int operatorId;
private final PlanNodeId planNodeId;
private final List probeTypes;
private final List buildOutputTypes;
private final JoinType joinType;
private final boolean outputSingleMatch;
private final boolean waitForBuild;
private final JoinProbeFactory joinProbeFactory;
private final Optional outerOperatorFactory;
private final JoinBridgeManager extends LookupSourceFactory> joinBridgeManager;
private final OptionalInt totalOperatorsCount;
private final HashGenerator probeHashGenerator;
private final PartitioningSpillerFactory partitioningSpillerFactory;
private boolean closed;
public LookupJoinOperatorFactory(
int operatorId,
PlanNodeId planNodeId,
JoinBridgeManager extends LookupSourceFactory> lookupSourceFactoryManager,
List probeTypes,
List probeOutputTypes,
List buildOutputTypes,
JoinOperatorType joinOperatorType,
JoinProbeFactory joinProbeFactory,
TypeOperators typeOperators,
OptionalInt totalOperatorsCount,
List probeJoinChannels,
OptionalInt probeHashChannel,
PartitioningSpillerFactory partitioningSpillerFactory)
{
this.operatorId = operatorId;
this.planNodeId = requireNonNull(planNodeId, "planNodeId is null");
this.probeTypes = ImmutableList.copyOf(requireNonNull(probeTypes, "probeTypes is null"));
this.buildOutputTypes = ImmutableList.copyOf(requireNonNull(buildOutputTypes, "buildOutputTypes is null"));
this.joinType = requireNonNull(joinOperatorType.getType(), "joinType is null");
this.outputSingleMatch = joinOperatorType.isOutputSingleMatch();
this.waitForBuild = joinOperatorType.isWaitForBuild();
this.joinProbeFactory = requireNonNull(joinProbeFactory, "joinProbeFactory is null");
this.joinBridgeManager = lookupSourceFactoryManager;
joinBridgeManager.incrementProbeFactoryCount();
if (joinType == INNER || joinType == PROBE_OUTER) {
this.outerOperatorFactory = Optional.empty();
}
else {
this.outerOperatorFactory = Optional.of(new LookupOuterOperatorFactory(
operatorId,
planNodeId,
probeOutputTypes,
buildOutputTypes,
lookupSourceFactoryManager));
}
this.totalOperatorsCount = requireNonNull(totalOperatorsCount, "totalOperatorsCount is null");
requireNonNull(probeHashChannel, "probeHashChannel is null");
if (probeHashChannel.isPresent()) {
this.probeHashGenerator = new PrecomputedHashGenerator(probeHashChannel.getAsInt());
}
else {
requireNonNull(probeJoinChannels, "probeJoinChannels is null");
List hashTypes = probeJoinChannels.stream()
.map(probeTypes::get)
.collect(toImmutableList());
this.probeHashGenerator = createChannelsHashGenerator(hashTypes, Ints.toArray(probeJoinChannels), typeOperators);
}
this.partitioningSpillerFactory = requireNonNull(partitioningSpillerFactory, "partitioningSpillerFactory is null");
}
private LookupJoinOperatorFactory(LookupJoinOperatorFactory other)
{
requireNonNull(other, "other is null");
checkArgument(!other.closed, "cannot duplicated closed OperatorFactory");
operatorId = other.operatorId;
planNodeId = other.planNodeId;
probeTypes = other.probeTypes;
buildOutputTypes = other.buildOutputTypes;
joinType = other.joinType;
outputSingleMatch = other.outputSingleMatch;
waitForBuild = other.waitForBuild;
joinProbeFactory = other.joinProbeFactory;
outerOperatorFactory = other.outerOperatorFactory;
joinBridgeManager = other.joinBridgeManager;
totalOperatorsCount = other.totalOperatorsCount;
probeHashGenerator = other.probeHashGenerator;
partitioningSpillerFactory = other.partitioningSpillerFactory;
closed = false;
joinBridgeManager.incrementProbeFactoryCount();
}
@Override
public Optional createOuterOperatorFactory()
{
return outerOperatorFactory;
}
@Override
public int getOperatorId()
{
return operatorId;
}
@Override
public PlanNodeId getPlanNodeId()
{
return planNodeId;
}
@Override
public String getOperatorType()
{
return LookupJoinOperator.class.getSimpleName();
}
@Override
public WorkProcessorOperator create(ProcessorContext processorContext, WorkProcessor sourcePages)
{
checkState(!closed, "Factory is already closed");
LookupSourceFactory lookupSourceFactory = joinBridgeManager.getJoinBridge();
joinBridgeManager.probeOperatorCreated();
return new LookupJoinOperator(
probeTypes,
buildOutputTypes,
joinType,
outputSingleMatch,
waitForBuild,
lookupSourceFactory,
joinProbeFactory,
joinBridgeManager::probeOperatorClosed,
totalOperatorsCount,
probeHashGenerator,
partitioningSpillerFactory,
processorContext,
sourcePages);
}
@Override
public void close()
{
joinBridgeManager.probeOperatorFactoryClosed();
checkState(!closed);
closed = true;
}
@Override
public LookupJoinOperatorFactory duplicate()
{
return new LookupJoinOperatorFactory(this);
}
}