Class Operation
- java.lang.Object
-
- org.apache.cassandra.utils.AbstractGuavaIterator<T>
-
- org.apache.cassandra.index.sasi.utils.RangeIterator<java.lang.Long,Token>
-
- org.apache.cassandra.index.sasi.plan.Operation
-
- All Implemented Interfaces:
com.google.common.collect.PeekingIterator<Token>
,java.io.Closeable
,java.lang.AutoCloseable
,java.util.Iterator<Token>
public class Operation extends RangeIterator<java.lang.Long,Token>
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static class
Operation.Builder
static class
Operation.OperationType
-
Nested classes/interfaces inherited from class org.apache.cassandra.utils.AbstractGuavaIterator
AbstractGuavaIterator.State
-
-
Field Summary
Fields Modifier and Type Field Description protected com.google.common.collect.ListMultimap<ColumnMetadata,Expression>
expressions
protected Operation
left
protected Operation.OperationType
op
protected RangeIterator<java.lang.Long,Token>
range
protected Operation
right
-
Fields inherited from class org.apache.cassandra.utils.AbstractGuavaIterator
next, state
-
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description protected static com.google.common.collect.ListMultimap<ColumnMetadata,Expression>
analyzeGroup(QueryController controller, Operation.OperationType op, java.util.List<RowFilter.Expression> expressions)
void
close()
protected Token
computeNext()
Returns the next element.protected void
performSkipTo(java.lang.Long nextToken)
boolean
satisfiedBy(Unfiltered currentCluster, Row staticRow, boolean allowMissingColumns)
Recursive "satisfies" checks based on operation and data from the lower level members using depth-first search and bubbling the results back to the top level caller.-
Methods inherited from class org.apache.cassandra.index.sasi.utils.RangeIterator
getCount, getCurrent, getMaximum, getMinimum, isOverlapping, isOverlapping, recomputeNext, skipTo, tryToComputeNext
-
Methods inherited from class org.apache.cassandra.utils.AbstractGuavaIterator
endOfData, hasNext, next, peek, remove
-
-
-
-
Field Detail
-
op
protected final Operation.OperationType op
-
expressions
protected final com.google.common.collect.ListMultimap<ColumnMetadata,Expression> expressions
-
range
protected final RangeIterator<java.lang.Long,Token> range
-
left
protected Operation left
-
right
protected Operation right
-
-
Method Detail
-
satisfiedBy
public boolean satisfiedBy(Unfiltered currentCluster, Row staticRow, boolean allowMissingColumns)
Recursive "satisfies" checks based on operation and data from the lower level members using depth-first search and bubbling the results back to the top level caller. Most of the work here is done bylocalSatisfiedBy(Unfiltered, Row, boolean)
see it's comment for details, if there are no local expressions assigned to Operation it will call satisfiedBy(Row) on it's children. Query: first_name = X AND (last_name = Y OR address = XYZ AND street = IL AND city = C) OR (state = 'CA' AND country = 'US') Row: key1: (first_name: X, last_name: Z, address: XYZ, street: IL, city: C, state: NY, country:US) #1 OR / \ #2 (first_name) AND AND (state, country) \ #3 (last_name) OR \ #4 AND (address, street, city) Evaluation of the key1 is top-down depth-first search: --- going down --- Level #1 is evaluated, OR expression has to pull results from it's children which are at level #2 and OR them together, Level #2 AND (state, country) could be be evaluated right away, AND (first_name) refers to it's "right" child from level #3 Level #3 OR (last_name) requests results from level #4 Level #4 AND (address, street, city) does logical AND between it's 3 fields, returns result back to level #3. --- bubbling up --- Level #3 computes OR between AND (address, street, city) result and it's "last_name" expression Level #2 computes AND between "first_name" and result of level #3, AND (state, country) which is already computed Level #1 does OR between results of AND (first_name) and AND (state, country) and returns final result.- Parameters:
currentCluster
- The row cluster to check.staticRow
- The static row associated with current cluster.allowMissingColumns
- allow columns value to be null.- Returns:
- true if give Row satisfied all of the expressions in the tree, false otherwise.
-
analyzeGroup
protected static com.google.common.collect.ListMultimap<ColumnMetadata,Expression> analyzeGroup(QueryController controller, Operation.OperationType op, java.util.List<RowFilter.Expression> expressions)
-
computeNext
protected Token computeNext()
Description copied from class:AbstractGuavaIterator
Returns the next element. Note: the implementation must callAbstractGuavaIterator.endOfData()
when there are no elements left in the iteration. Failure to do so could result in an infinite loop.The initial invocation of
AbstractGuavaIterator.hasNext()
orAbstractGuavaIterator.next()
calls this method, as does the first invocation ofhasNext
ornext
following each successful call tonext
. Once the implementation either invokesendOfData
or throws an exception,computeNext
is guaranteed to never be called again.If this method throws an exception, it will propagate outward to the
hasNext
ornext
invocation that invoked this method. Any further attempts to use the iterator will result in anIllegalStateException
.The implementation of this method may not invoke the
hasNext
,next
, orAbstractGuavaIterator.peek()
methods on this instance; if it does, anIllegalStateException
will result.- Specified by:
computeNext
in classAbstractGuavaIterator<Token>
- Returns:
- the next element if there was one. If
endOfData
was called during execution, the return value will be ignored.
-
performSkipTo
protected void performSkipTo(java.lang.Long nextToken)
- Specified by:
performSkipTo
in classRangeIterator<java.lang.Long,Token>
-
close
public void close() throws java.io.IOException
- Throws:
java.io.IOException
-
-