Class VTIDeferModPolicy
- java.lang.Object
-
- org.apache.derby.impl.sql.compile.VTIDeferModPolicy
-
-
Field Summary
Fields Modifier and Type Field Description private java.util.HashSet<java.lang.String>
columns
private DeferModification
deferralControl
private boolean
deferred
private int
statementType
private int
tableNumber
-
Constructor Summary
Constructors Modifier Constructor Description private
VTIDeferModPolicy(FromVTI targetVTI, java.lang.String[] columnNames, DeferModification deferralControl, int statementType)
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description static boolean
deferIt(int statementType, FromVTI targetVTI, java.lang.String[] updateColumnNames, QueryTreeNode source)
See if a VTI modification statement should be deferred.boolean
skipChildren(Visitable node)
Method that is called to indicate whether we should skip all nodes below this node for traversal.boolean
stopTraversal()
Method that is called to see if query tree traversal should be stopped before visiting all nodes.Visitable
visit(Visitable node)
This is the default visit operation on a QueryTreeNode.boolean
visitChildrenFirst(Visitable node)
Method that is called to see ifvisit()
should be called on the children ofnode
before it is called onnode
itself.
-
-
-
Field Detail
-
deferred
private boolean deferred
-
deferralControl
private DeferModification deferralControl
-
statementType
private int statementType
-
tableNumber
private int tableNumber
-
columns
private final java.util.HashSet<java.lang.String> columns
-
-
Constructor Detail
-
VTIDeferModPolicy
private VTIDeferModPolicy(FromVTI targetVTI, java.lang.String[] columnNames, DeferModification deferralControl, int statementType)
-
-
Method Detail
-
deferIt
public static boolean deferIt(int statementType, FromVTI targetVTI, java.lang.String[] updateColumnNames, QueryTreeNode source) throws StandardException
See if a VTI modification statement should be deferred.- Parameters:
statementType
- DeferModification.INSERT_STATEMENT, UPDATE_STATEMENT, or DELETE_STATEMENTtargetVTI
- The target VTIupdateColumnNames
- The list of columns being updated, null if this is not an update statementsource
-- Throws:
StandardException
-
visit
public Visitable visit(Visitable node) throws StandardException
Description copied from interface:Visitor
This is the default visit operation on a QueryTreeNode. It just returns the node. This will typically suffice as the default visit operation for most visitors unless the visitor needs to count the number of nodes visited or something like that.Visitors will overload this method by implementing a version with a signature that matches a specific type of node. For example, if I want to do something special with aggregate nodes, then that Visitor will implement a visit(AggregateNode node) method which does the aggregate specific processing.
- Specified by:
visit
in interfaceVisitor
- Parameters:
node
- the node to process- Returns:
- a query tree node. Often times this is the same node that was passed in, but Visitors that replace nodes with other nodes will use this to return the new replacement node.
- Throws:
StandardException
- may be throw an error as needed by the visitor (i.e. may be a normal error if a particular node is found, e.g. if checking a group by, we don't expect to find any ColumnReferences that aren't under an AggregateNode -- the easiest thing to do is just throw an error when we find the questionable node).
-
stopTraversal
public boolean stopTraversal()
Description copied from interface:Visitor
Method that is called to see if query tree traversal should be stopped before visiting all nodes. Useful for short circuiting traversal if we already know we are done.- Specified by:
stopTraversal
in interfaceVisitor
- Returns:
- true/false
-
skipChildren
public boolean skipChildren(Visitable node)
Description copied from interface:Visitor
Method that is called to indicate whether we should skip all nodes below this node for traversal. Useful if we want to effectively ignore/prune all branches under a particular node.Differs from stopTraversal() in that it only affects subtrees, rather than the entire traversal.
- Specified by:
skipChildren
in interfaceVisitor
- Parameters:
node
- the node to process- Returns:
- true/false
-
visitChildrenFirst
public boolean visitChildrenFirst(Visitable node)
Description copied from interface:Visitor
Method that is called to see ifvisit()
should be called on the children ofnode
before it is called onnode
itself. If this method always returnstrue
, the visitor will walk the tree bottom-up. If it always returnsfalse
, the tree is visited top-down.- Specified by:
visitChildrenFirst
in interfaceVisitor
- Parameters:
node
- the top node of a sub-tree about to be visited- Returns:
true
ifnode
's children should be visited beforenode
,false
otherwise
-
-