Package org.apache.calcite.rel.core
Class Snapshot
java.lang.Object
org.apache.calcite.rel.AbstractRelNode
org.apache.calcite.rel.SingleRel
org.apache.calcite.rel.core.Snapshot
- All Implemented Interfaces:
- Cloneable,- RelOptNode,- Hintable,- RelNode
- Direct Known Subclasses:
- LogicalSnapshot
Relational expression that returns the contents of a relation expression as
 it was at a given time in the past.
 
For example, if Products is a temporal table, and
 TableScan(Products) is a relational operator that returns all
 versions of the contents of the table, then
 Snapshot(TableScan(Products)) is a relational operator that only
 returns the contents whose versions that overlap with the given specific
 period (i.e. those that started before given period and ended after it).
- 
Nested Class SummaryNested classes/interfaces inherited from interface org.apache.calcite.rel.RelNodeRelNode.Context
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected final com.google.common.collect.ImmutableList<RelHint>Fields inherited from class org.apache.calcite.rel.AbstractRelNodedigest, id, rowType, traitSet
- 
Constructor SummaryConstructorsModifierConstructorDescriptionprotectedSnapshot(RelOptCluster cluster, RelTraitSet traitSet, List<RelHint> hints, RelNode input, RexNode period) Creates a Snapshot.protectedSnapshot(RelOptCluster cluster, RelTraitSet traitSet, RelNode input, RexNode period) Creates a Snapshot.Creates a Snapshot by parsing serialized output.
- 
Method SummaryModifier and TypeMethodDescriptionaccept(RexShuttle shuttle) Accepts a visit from a shuttle.final RelNodecopy(RelTraitSet traitSet, List<RelNode> inputs) Creates a copy of this relational expression, perhaps changing traits and inputs.abstract Snapshotcopy(RelTraitSet traitSet, RelNode input, RexNode period) Describes the inputs and attributes of this relational expression.com.google.common.collect.ImmutableList<RelHint>getHints()Returns the hints of this relational expressions as an immutable list.booleanisValid(Litmus litmus, @Nullable RelNode.Context context) Returns whether this relational expression is valid.Methods inherited from class org.apache.calcite.rel.SingleRelchildrenAccept, deriveRowType, estimateRowCount, getInput, getInputs, replaceInputMethods inherited from class org.apache.calcite.rel.AbstractRelNodeaccept, collectVariablesSet, collectVariablesUsed, computeSelfCost, deepEquals, deepHashCode, equals, explain, getCluster, getConvention, getCorrelVariable, getDescription, getDigest, getExpectedInputRowType, getId, getInput, getRelDigest, getRelTypeName, getRowType, getTable, getTraitSet, getVariablesSet, hashCode, isEnforcer, metadata, onRegister, recomputeDigest, register, sole, toStringMethods inherited from class java.lang.Objectclone, finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface org.apache.calcite.rel.hint.HintableattachHints, withHintsMethods inherited from interface org.apache.calcite.rel.RelNodeexplain, fieldIsNullable, stripped
- 
Field Details- 
hints
 
- 
- 
Constructor Details- 
SnapshotCreates a Snapshot by parsing serialized output.
- 
Snapshotprotected Snapshot(RelOptCluster cluster, RelTraitSet traitSet, List<RelHint> hints, RelNode input, RexNode period) Creates a Snapshot.- Parameters:
- cluster- Cluster that this relational expression belongs to
- traitSet- The traits of this relational expression
- hints- Hints for this node
- input- Input relational expression
- period- Timestamp expression which as the table was at the given time in the past
 
- 
SnapshotCreates a Snapshot.- Parameters:
- cluster- Cluster that this relational expression belongs to
- traitSet- The traits of this relational expression
- input- Input relational expression
- period- Timestamp expression which as the table was at the given time in the past
 
 
- 
- 
Method Details- 
copyDescription copied from interface:RelNodeCreates a copy of this relational expression, perhaps changing traits and inputs.Sub-classes with other important attributes are encouraged to create variants of this method with more parameters. - Specified by:
- copyin interface- RelNode
- Overrides:
- copyin class- AbstractRelNode
- Parameters:
- traitSet- Trait set
- inputs- Inputs
- Returns:
- Copy of this relational expression, substituting traits and inputs
 
- 
copy
- 
acceptDescription copied from interface:RelNodeAccepts a visit from a shuttle. If the shuttle updates expression, then a copy of the relation should be created. This new relation might have a different row-type.- Specified by:
- acceptin interface- RelNode
- Overrides:
- acceptin class- AbstractRelNode
- Parameters:
- shuttle- Shuttle
- Returns:
- A copy of this node incorporating changes made by the shuttle to this node's children
 
- 
explainTermsDescription copied from class:AbstractRelNodeDescribes the inputs and attributes of this relational expression. Each node should callsuper.explainTerms, then call theRelWriter.input(String, RelNode)andRelWriter.item(String, Object)methods for each input and attribute.- Overrides:
- explainTermsin class- SingleRel
- Parameters:
- pw- Plan writer
- Returns:
- Plan writer for fluent-explain pattern
 
- 
getPeriod
- 
isValidDescription copied from interface:RelNodeReturns whether this relational expression is valid.If assertions are enabled, this method is typically called with litmus=THROW, as follows:assert rel.isValid(Litmus.THROW) This signals that the method can throw an AssertionErrorif it is not valid.- Specified by:
- isValidin interface- RelNode
- Overrides:
- isValidin class- AbstractRelNode
- Parameters:
- litmus- What to do if invalid
- context- Context for validity checking
- Returns:
- Whether relational expression is valid
 
- 
getHintsDescription copied from interface:HintableReturns the hints of this relational expressions as an immutable list.
 
-