Class PhysicalOpHashRJoin
java.lang.Object
se.liu.ida.hefquin.engine.queryplan.physical.impl.BaseForPhysicalOps
se.liu.ida.hefquin.engine.queryplan.physical.impl.PhysicalOpHashRJoin
- All Implemented Interfaces:
BinaryPhysicalOp
,BinaryPhysicalOpForLogicalOp
,PhysicalOperator
,PhysicalOperatorForLogicalOperator
A physical operator that implements the hash join algorithm to perform
a right outer join of two sequences of input solution mappings (produced
by the two sub-plans under this operator). The hash join algorithm builds
a hash table with the solution mappings of the first input sequence (using
the values that they have for the join variables to decide where to place
them in the hash table) and, thereafter, probes the hash table to find join
partners for each of the solution mappings of the second input sequence.
As this operator performs a right outer join, the solution mappings of the
second input sequence that do not have a join partner are not discarded (as
would be the case for an inner join) but, instead, are passed to the output
as is.
The actual algorithm of this operator is implemented in the
ExecOpHashRJoin
class.-
Field Summary
FieldsFields inherited from class se.liu.ida.hefquin.engine.queryplan.physical.impl.BaseForPhysicalOps
id
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptioncreateExecOp
(boolean collectExceptions, ExpectedVariables... inputVars) Creates and returns the executable operator to be used for this physical operator.boolean
getExpectedVariables
(ExpectedVariables... inputVars) Returns the variables that can be expected in the solution mappings produced by this operator if the input(s) to this operator contain solutions mappings with the given set(s) of variables.Returns the logical operator implemented by this physical operator.int
hashCode()
toString()
void
visit
(PhysicalPlanVisitor visitor) Methods inherited from class se.liu.ida.hefquin.engine.queryplan.physical.impl.BaseForPhysicalOps
getID
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
Methods inherited from interface se.liu.ida.hefquin.engine.queryplan.physical.PhysicalOperator
getID
-
Field Details
-
lop
-
-
Constructor Details
-
PhysicalOpHashRJoin
-
-
Method Details
-
getLogicalOperator
Description copied from interface:PhysicalOperatorForLogicalOperator
Returns the logical operator implemented by this physical operator.- Specified by:
getLogicalOperator
in interfaceBinaryPhysicalOpForLogicalOp
- Specified by:
getLogicalOperator
in interfacePhysicalOperatorForLogicalOperator
-
getExpectedVariables
Description copied from interface:PhysicalOperator
Returns the variables that can be expected in the solution mappings produced by this operator if the input(s) to this operator contain solutions mappings with the given set(s) of variables. The number ofExpectedVariables
objects passed to this method must be in line with the degree of this operator (e.g., for a unary operator, exactly one such object must be passed).- Specified by:
getExpectedVariables
in interfacePhysicalOperator
-
createExecOp
Description copied from interface:PhysicalOperator
Creates and returns the executable operator to be used for this physical operator. The implementation of this method has to create a newExecutableOperator
object each time it is called. The given collectExceptions flag is passed to the executable operator and determines whether that operator collects its exceptions (seeExecutableOperator.getExceptionsCaughtDuringExecution()
) or throws them immediately. The number ofExpectedVariables
objects passed as arguments to this method must be in line with the degree of this operator (e.g., for a unary operator, exactly one such object must be passed).- Specified by:
createExecOp
in interfaceBinaryPhysicalOp
- Specified by:
createExecOp
in interfacePhysicalOperator
-
visit
- Specified by:
visit
in interfacePhysicalOperator
-
equals
-
hashCode
public int hashCode() -
toString
-