Class SinglePartitionReadCommand.VirtualTableSinglePartitionReadCommand
- java.lang.Object
-
- org.apache.cassandra.db.monitoring.MonitorableImpl
-
- org.apache.cassandra.db.ReadCommand
-
- org.apache.cassandra.db.SinglePartitionReadCommand
-
- org.apache.cassandra.db.SinglePartitionReadCommand.VirtualTableSinglePartitionReadCommand
-
- All Implemented Interfaces:
Monitorable
,ReadQuery
,SinglePartitionReadQuery
- Enclosing class:
- SinglePartitionReadCommand
public static class SinglePartitionReadCommand.VirtualTableSinglePartitionReadCommand extends SinglePartitionReadCommand
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from class org.apache.cassandra.db.SinglePartitionReadCommand
SinglePartitionReadCommand.Group, SinglePartitionReadCommand.VirtualTableGroup, SinglePartitionReadCommand.VirtualTableSinglePartitionReadCommand
-
Nested classes/interfaces inherited from class org.apache.cassandra.db.ReadCommand
ReadCommand.Kind, ReadCommand.SelectionDeserializer, ReadCommand.Serializer
-
-
Field Summary
-
Fields inherited from class org.apache.cassandra.db.SinglePartitionReadCommand
clusteringIndexFilter, partitionKey, selectionDeserializer
-
Fields inherited from class org.apache.cassandra.db.ReadCommand
logger, serializer
-
-
Constructor Summary
Constructors Modifier Constructor Description protected
VirtualTableSinglePartitionReadCommand(boolean isDigest, int digestVersion, boolean acceptsTransient, TableMetadata metadata, long nowInSec, ColumnFilter columnFilter, RowFilter rowFilter, DataLimits limits, DecoratedKey partitionKey, ClusteringIndexFilter clusteringIndexFilter, Index.QueryPlan indexQueryPlan, boolean trackWarnings)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description ColumnFilter
columnFilter()
A filter on which (non-PK) columns must be returned by the query.PartitionIterator
execute(ConsistencyLevel consistency, ClientState state, Dispatcher.RequestTime requestTime)
Executes the query at the provided consistency level.PartitionIterator
executeInternal(ReadExecutionController controller)
Execute the query for internal queries (that is, it basically executes the query locally).UnfilteredPartitionIterator
executeLocally(ReadExecutionController executionController)
Executes this command on the local host.ReadExecutionController
executionController()
Starts a new read operation.ReadExecutionController
executionController(boolean trackRepairedStatus)
DataLimits
limits()
The limits for the query.TableMetadata
metadata()
The metadata for the table this is a query on.long
nowInSec()
The time in seconds to use as "now" for this query.RowFilter
rowFilter()
Filters/Resrictions on CQL rows.java.lang.String
toCQLString()
Recreate the CQL string corresponding to this query.-
Methods inherited from class org.apache.cassandra.db.SinglePartitionReadCommand
appendCQLWhereClause, clusteringIndexFilter, clusteringIndexFilter, copy, copyAsDigestQuery, copyAsTransientQuery, create, create, create, create, create, create, create, create, forPaging, fullPartitionRead, fullPartitionRead, getTimeout, intersects, isLimitedToOnePartition, isRangeRequest, isReversed, loggableTokens, partitionKey, queryMemtableAndDisk, queryStorage, recordLatency, selectionSerializedSize, selectsFullPartition, serializeSelection, toString, verb, withUpdatedLimit
-
Methods inherited from class org.apache.cassandra.db.ReadCommand
acceptsTransient, copyAsDigestQuery, copyAsDigestQuery, copyAsTransientQuery, copyAsTransientQuery, createEmptyResponse, createMessage, createResponse, digestVersion, getCommand, hasPartitionLevelDeletions, hasRequiredStatics, indexQueryPlan, indexSearcher, isDigestQuery, isTopK, isTrackingWarnings, maybeValidateIndex, name, setDigestVersion, trackWarnings, withoutPurgeableTombstones
-
Methods inherited from class org.apache.cassandra.db.monitoring.MonitorableImpl
abort, complete, creationTimeNanos, isAborted, isCompleted, isCrossNode, isInProgress, isSlow, setMonitoringTime, slowTimeoutNanos, timeoutNanos
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface org.apache.cassandra.db.ReadQuery
columnFilter, executeInternal, isEmpty, isTopK, limits, maybeValidateIndex, metadata, nowInSec, rowFilter, trackWarnings
-
Methods inherited from interface org.apache.cassandra.db.SinglePartitionReadQuery
getPager, selectsClustering, selectsKey
-
-
-
-
Constructor Detail
-
VirtualTableSinglePartitionReadCommand
protected VirtualTableSinglePartitionReadCommand(boolean isDigest, int digestVersion, boolean acceptsTransient, TableMetadata metadata, long nowInSec, ColumnFilter columnFilter, RowFilter rowFilter, DataLimits limits, DecoratedKey partitionKey, ClusteringIndexFilter clusteringIndexFilter, Index.QueryPlan indexQueryPlan, boolean trackWarnings)
-
-
Method Detail
-
execute
public PartitionIterator execute(ConsistencyLevel consistency, ClientState state, Dispatcher.RequestTime requestTime) throws RequestExecutionException
Description copied from interface:ReadQuery
Executes the query at the provided consistency level.- Specified by:
execute
in interfaceReadQuery
- Overrides:
execute
in classSinglePartitionReadCommand
- Parameters:
consistency
- the consistency level to achieve for the query.state
- client state- Returns:
- the result of the query.
- Throws:
RequestExecutionException
-
executeLocally
public UnfilteredPartitionIterator executeLocally(ReadExecutionController executionController)
Description copied from class:ReadCommand
Executes this command on the local host.- Specified by:
executeLocally
in interfaceReadQuery
- Overrides:
executeLocally
in classReadCommand
- Parameters:
executionController
- the execution controller spanning this command- Returns:
- an iterator over the result of executing this command locally.
-
executionController
public ReadExecutionController executionController()
Description copied from interface:ReadQuery
Starts a new read operation.This must be called before
ReadQuery.executeInternal(org.apache.cassandra.db.ReadExecutionController)
and passed to it to protect the read. The returned object must be closed on all path and it is thus strongly advised to use it in a try-with-ressource construction.- Specified by:
executionController
in interfaceReadQuery
- Overrides:
executionController
in classReadCommand
- Returns:
- a newly started execution controller for this
ReadQuery
.
-
executionController
public ReadExecutionController executionController(boolean trackRepairedStatus)
- Overrides:
executionController
in classReadCommand
-
metadata
public TableMetadata metadata()
Description copied from interface:ReadQuery
The metadata for the table this is a query on.
-
executeInternal
public PartitionIterator executeInternal(ReadExecutionController controller)
Description copied from interface:ReadQuery
Execute the query for internal queries (that is, it basically executes the query locally).- Specified by:
executeInternal
in interfaceReadQuery
- Parameters:
controller
- theReadExecutionController
protecting the read.- Returns:
- the result of the query.
-
limits
public DataLimits limits()
Description copied from interface:ReadQuery
The limits for the query.
-
nowInSec
public long nowInSec()
Description copied from interface:ReadQuery
The time in seconds to use as "now" for this query.We use the same time as "now" for the whole query to avoid considering different values as expired during the query, which would be buggy (would throw of counting amongst other things).
-
rowFilter
public RowFilter rowFilter()
Description copied from interface:ReadQuery
Filters/Resrictions on CQL rows.This contains the restrictions that are not directly handled by the
ClusteringIndexFilter
. More specifically, this includes any non-PK column restrictions and can include some PK columns restrictions when those can't be satisfied entirely by the clustering index filter (because not all clustering columns have been restricted for instance). If there is 2ndary indexes on the table, one of this restriction might be handled by a 2ndary index.
-
columnFilter
public ColumnFilter columnFilter()
Description copied from interface:ReadQuery
A filter on which (non-PK) columns must be returned by the query.- Specified by:
columnFilter
in interfaceReadQuery
- Returns:
- which columns must be fetched by this query.
-
toCQLString
public java.lang.String toCQLString()
Recreate the CQL string corresponding to this query.Note that in general the returned string will not be exactly the original user string, first because there isn't always a single syntax for a given query, but also because we don't have all the information needed (we know the non-PK columns queried but not the PK ones as internally we query them all). So this shouldn't be relied too strongly, but this should be good enough for debugging purpose which is what this is for.
-
-