org.eigenbase.rel
Class IntersectRel
java.lang.Object
org.eigenbase.rel.AbstractRelNode
org.eigenbase.rel.SetOpRel
org.eigenbase.rel.IntersectRel
- All Implemented Interfaces:
- Cloneable, RelNode
public final class IntersectRel
- extends SetOpRel
IntersectRel
returns the intersection of the rows of its inputs.
If "all" is true, then multiset intersection is performed; otherwise, set
intersection is performed (implying no duplicates in the results).
- Since:
- 23 September, 2001
- Version:
- $Id: //open/dev/farrago/src/org/eigenbase/rel/IntersectRel.java#13 $
- Author:
- jhyde
Methods inherited from class org.eigenbase.rel.AbstractRelNode |
childrenAccept, cloneTraits, collectVariablesSet, collectVariablesUsed, computeDigest, computeSelfCost, getChildExps, getCluster, getCollationList, getConvention, getCorrelVariable, getDescription, getDigest, getExpectedInputRowType, getId, getInput, getOrCreateCorrelVariable, getQuery, getRelTypeName, getRowType, getTable, getTraits, getVariablesStopped, inheritTraitsFrom, isAccessTo, isValid, onRegister, recomputeDigest, register, registerCorrelVariable, setCorrelVariable, toString |
IntersectRel
public IntersectRel(RelOptCluster cluster,
RelNode[] inputs,
boolean all)
getRows
public double getRows()
- Description copied from interface:
RelNode
- Returns an estimate of the number of rows this relational expression will
return.
NOTE jvs 29-Mar-2006: Don't call this method directly. Instead, use
RelMetadataQuery.getRowCount(org.eigenbase.rel.RelNode)
, which gives plugins a chance to
override the rel's default ideas about row count.
- Specified by:
getRows
in interface RelNode
- Overrides:
getRows
in class AbstractRelNode
clone
public IntersectRel clone()
- Description copied from interface:
RelNode
- Clones this RelNode.
Traits of the RelNode must be explicitly cloned, using AbstractRelNode.inheritTraitsFrom(AbstractRelNode)
, as the RelNode may
have traits of which it has no knowledge. Example implementation:
public MyRelNode clone()
{
MyRelNode clone = new MyRelNode(...);
clone.inheritTraitsFrom(this);
return clone;
}
N.B.: This method must be overridden whenever an existing,
concrete RelNode is extended. Otherwise, calling clone() will produce a
differently typed RelNode, resulting in invalid or incorrect query plans.
- Specified by:
clone
in interface RelNode
- Specified by:
clone
in class AbstractRelNode
- Returns:
- a clone of this RelNode
clone
public IntersectRel clone(RelNode[] inputs,
boolean all)
- Specified by:
clone
in class SetOpRel