Impala
Impalaistheopensource,nativeanalyticdatabaseforApacheHadoop.
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros
com.cloudera.impala.planner.SortNode Class Reference
Inheritance diagram for com.cloudera.impala.planner.SortNode:
Collaboration diagram for com.cloudera.impala.planner.SortNode:

Public Member Functions

 SortNode (PlanNodeId id, PlanNode input, SortInfo info, boolean useTopN, long offset)
 
long getOffset ()
 
void setOffset (long offset)
 
boolean hasOffset ()
 
boolean useTopN ()
 
SortInfo getSortInfo ()
 
void setInputPartition (DataPartition inputPartition)
 
DataPartition getInputPartition ()
 
boolean isAnalyticSort ()
 
void setIsAnalyticSort (boolean v)
 
boolean isBlockingNode ()
 
void init (Analyzer analyzer) throws InternalException
 
void computeCosts (TQueryOptions queryOptions)
 
PlanNodeId getId ()
 
void setId (PlanNodeId id)
 
long getLimit ()
 
boolean hasLimit ()
 
long getPerHostMemCost ()
 
long getCardinality ()
 
int getNumNodes ()
 
float getAvgRowSize ()
 
void setFragment (PlanFragment fragment)
 
PlanFragment getFragment ()
 
List< ExprgetConjuncts ()
 
ExprSubstitutionMap getOutputSmap ()
 
void setOutputSmap (ExprSubstitutionMap smap)
 
Set< ExprIdgetAssignedConjuncts ()
 
void setAssignedConjuncts (Set< ExprId > conjuncts)
 
void setLimit (long limit)
 
void unsetLimit ()
 
ArrayList< TupleIdgetTupleIds ()
 
ArrayList< TupleIdgetTblRefIds ()
 
void setTblRefIds (ArrayList< TupleId > ids)
 
Set< TupleIdgetNullableTupleIds ()
 
void addConjuncts (List< Expr > conjuncts)
 
void transferConjuncts (PlanNode recipient)
 
String getExplainString ()
 
TPlan treeToThrift ()
 
long getInputCardinality ()
 

Static Public Member Functions

static long addCardinalities (long a, long b)
 
static long multiplyCardinalities (long a, long b)
 

Protected Member Functions

void computeStats (Analyzer analyzer)
 
String debugString ()
 
void toThrift (TPlanNode msg)
 
String getNodeExplainString (String prefix, String detailPrefix, TExplainLevel detailLevel)
 
String getOffsetExplainString (String prefix)
 
final String getExplainString (String rootPrefix, String prefix, TExplainLevel detailLevel)
 
String getExplainString (List<?extends Expr > exprs)
 
void setDisplayName (String s)
 
final String getDisplayLabel ()
 
String getDisplayLabelDetail ()
 
void assignConjuncts (Analyzer analyzer)
 
ExprSubstitutionMap getCombinedChildSmap ()
 
void createDefaultSmap (Analyzer analyzer)
 
long capAtLimit (long cardinality)
 
void markSlotsMaterialized (Analyzer analyzer, List< Expr > exprs)
 
void computeMemLayout (Analyzer analyzer)
 
double computeSelectivity ()
 
boolean hasValidStats ()
 

Protected Attributes

long offset_
 
String displayName_
 
PlanNodeId id_
 
long limit_
 
ArrayList< TupleIdtupleIds_
 
ArrayList< TupleIdtblRefIds_
 
Set< TupleIdnullableTupleIds_ = Sets.newHashSet()
 
List< Exprconjuncts_ = Lists.newArrayList()
 
PlanFragment fragment_
 
ExprSubstitutionMap outputSmap_
 
Set< ExprIdassignedConjuncts_
 
long cardinality_
 
int numNodes_
 
float avgRowSize_
 
long perHostMemCost_ = -1
 

Static Protected Attributes

static final int DEFAULT_BATCH_SIZE = 1024
 

Private Member Functions

String getNodeExplainDetail (TExplainLevel detailLevel)
 

Static Private Member Functions

static String getDisplayName (boolean isTopN, boolean isMergeOnly)
 

Private Attributes

final SortInfo info_
 
DataPartition inputPartition_
 
boolean isAnalyticSort_
 
List< ExprresolvedTupleExprs_
 
final boolean useTopN_
 

Static Private Attributes

static final Logger LOG = LoggerFactory.getLogger(SortNode.class)
 

Detailed Description

Node that implements a sort with or without a limit. useTopN_ is true for sorts with limits that are implemented by a TopNNode in the backend. SortNode is used otherwise. Will always materialize the new tuple info_.sortTupleDesc_.

Definition at line 47 of file SortNode.java.

Constructor & Destructor Documentation

Member Function Documentation

static long com.cloudera.impala.planner.PlanNode.addCardinalities ( long  a,
long  b 
)
inlinestaticinherited
void com.cloudera.impala.planner.PlanNode.addConjuncts ( List< Expr conjuncts)
inlineinherited

Definition at line 209 of file PlanNode.java.

void com.cloudera.impala.planner.SortNode.computeStats ( Analyzer  analyzer)
inlineprotected
void com.cloudera.impala.planner.PlanNode.createDefaultSmap ( Analyzer  analyzer)
inlineprotectedinherited
Set<ExprId> com.cloudera.impala.planner.PlanNode.getAssignedConjuncts ( )
inlineinherited
ExprSubstitutionMap com.cloudera.impala.planner.PlanNode.getCombinedChildSmap ( )
inlineprotectedinherited
List<Expr> com.cloudera.impala.planner.PlanNode.getConjuncts ( )
inlineinherited
String com.cloudera.impala.planner.PlanNode.getDisplayLabelDetail ( )
inlineprotectedinherited

Subclasses can override to provide a node specific detail string that is displayed to the user. e.g. scan can return the table name.

Definition at line 234 of file PlanNode.java.

Referenced by com.cloudera.impala.planner.PlanNode.treeToThriftHelper().

static String com.cloudera.impala.planner.SortNode.getDisplayName ( boolean  isTopN,
boolean  isMergeOnly 
)
inlinestaticprivate

Definition at line 230 of file SortNode.java.

Referenced by com.cloudera.impala.planner.SortNode.SortNode().

final String com.cloudera.impala.planner.PlanNode.getExplainString ( String  rootPrefix,
String  prefix,
TExplainLevel  detailLevel 
)
inlineprotectedinherited
String com.cloudera.impala.planner.PlanNode.getExplainString ( List<?extends Expr exprs)
inlineprotectedinherited

Definition at line 506 of file PlanNode.java.

PlanFragment com.cloudera.impala.planner.PlanNode.getFragment ( )
inlineinherited
long com.cloudera.impala.planner.PlanNode.getInputCardinality ( )
inlineinherited

The input cardinality is the sum of output cardinalities of its children. For scan nodes the input cardinality is the expected number of rows scanned.

Definition at line 570 of file PlanNode.java.

References com.cloudera.impala.planner.PlanNode.addCardinalities().

DataPartition com.cloudera.impala.planner.SortNode.getInputPartition ( )
inline
long com.cloudera.impala.planner.PlanNode.getLimit ( )
inlineinherited
String com.cloudera.impala.planner.SortNode.getNodeExplainDetail ( TExplainLevel  detailLevel)
inlineprivate
String com.cloudera.impala.planner.SortNode.getNodeExplainString ( String  prefix,
String  detailPrefix,
TExplainLevel  detailLevel 
)
inlineprotected
Set<TupleId> com.cloudera.impala.planner.PlanNode.getNullableTupleIds ( )
inlineinherited
long com.cloudera.impala.planner.SortNode.getOffset ( )
inline

Definition at line 75 of file SortNode.java.

References com.cloudera.impala.planner.SortNode.offset_.

String com.cloudera.impala.planner.SortNode.getOffsetExplainString ( String  prefix)
inlineprotected

Definition at line 194 of file SortNode.java.

References com.cloudera.impala.planner.SortNode.offset_.

ExprSubstitutionMap com.cloudera.impala.planner.PlanNode.getOutputSmap ( )
inlineinherited

Definition at line 178 of file PlanNode.java.

References com.cloudera.impala.planner.PlanNode.outputSmap_.

long com.cloudera.impala.planner.PlanNode.getPerHostMemCost ( )
inlineinherited
SortInfo com.cloudera.impala.planner.SortNode.getSortInfo ( )
inline

Definition at line 79 of file SortNode.java.

References com.cloudera.impala.planner.SortNode.info_.

ArrayList<TupleId> com.cloudera.impala.planner.PlanNode.getTblRefIds ( )
inlineinherited
boolean com.cloudera.impala.planner.SortNode.hasOffset ( )
inline
boolean com.cloudera.impala.planner.PlanNode.hasValidStats ( )
inlineprotectedinherited
boolean com.cloudera.impala.planner.SortNode.isAnalyticSort ( )
inline
boolean com.cloudera.impala.planner.SortNode.isBlockingNode ( )
inline

Definition at line 88 of file SortNode.java.

void com.cloudera.impala.planner.PlanNode.markSlotsMaterialized ( Analyzer  analyzer,
List< Expr exprs 
)
inlineprotectedinherited

Marks all slots referenced in exprs as materialized.

Definition at line 464 of file PlanNode.java.

Referenced by com.cloudera.impala.planner.HdfsScanNode.init().

static long com.cloudera.impala.planner.PlanNode.multiplyCardinalities ( long  a,
long  b 
)
inlinestaticinherited

Computes and returns the product of two cardinalities. If an overflow occurs, the maximum Long value is returned (Long.MAX_VALUE).

Definition at line 541 of file PlanNode.java.

Referenced by com.cloudera.impala.planner.CrossJoinNode.computeStats(), and com.cloudera.impala.planner.HashJoinNode.getJoinCardinality().

void com.cloudera.impala.planner.PlanNode.setAssignedConjuncts ( Set< ExprId conjuncts)
inlineinherited
void com.cloudera.impala.planner.PlanNode.setDisplayName ( String  s)
inlineprotectedinherited

Definition at line 223 of file PlanNode.java.

References com.cloudera.impala.planner.PlanNode.displayName_.

void com.cloudera.impala.planner.PlanNode.setFragment ( PlanFragment  fragment)
inlineinherited

Definition at line 175 of file PlanNode.java.

References com.cloudera.impala.planner.PlanNode.fragment_.

void com.cloudera.impala.planner.PlanNode.setId ( PlanNodeId  id)
inlineinherited

Definition at line 165 of file PlanNode.java.

References com.cloudera.impala.planner.PlanNode.id_.

void com.cloudera.impala.planner.SortNode.setInputPartition ( DataPartition  inputPartition)
inline
void com.cloudera.impala.planner.SortNode.setIsAnalyticSort ( boolean  v)
inline
void com.cloudera.impala.planner.PlanNode.setLimit ( long  limit)
inlineinherited

Set the limit_ to the given limit_ only if the limit_ hasn't been set, or the new limit_ is lower.

Parameters
limit_

Definition at line 190 of file PlanNode.java.

References com.cloudera.impala.planner.PlanNode.limit_.

void com.cloudera.impala.planner.SortNode.setOffset ( long  offset)
inline

Definition at line 76 of file SortNode.java.

References offset, and com.cloudera.impala.planner.SortNode.offset_.

void com.cloudera.impala.planner.PlanNode.setOutputSmap ( ExprSubstitutionMap  smap)
inlineinherited

Definition at line 179 of file PlanNode.java.

References com.cloudera.impala.planner.PlanNode.outputSmap_.

void com.cloudera.impala.planner.PlanNode.setTblRefIds ( ArrayList< TupleId ids)
inlineinherited

Definition at line 202 of file PlanNode.java.

References com.cloudera.impala.planner.PlanNode.tblRefIds_.

void com.cloudera.impala.planner.PlanNode.transferConjuncts ( PlanNode  recipient)
inlineinherited

Definition at line 214 of file PlanNode.java.

References com.cloudera.impala.planner.PlanNode.conjuncts_.

TPlan com.cloudera.impala.planner.PlanNode.treeToThrift ( )
inlineinherited
void com.cloudera.impala.planner.PlanNode.unsetLimit ( )
inlineinherited

Definition at line 194 of file PlanNode.java.

References com.cloudera.impala.planner.PlanNode.limit_.

boolean com.cloudera.impala.planner.SortNode.useTopN ( )
inline

Member Data Documentation

final int com.cloudera.impala.planner.PlanNode.DEFAULT_BATCH_SIZE = 1024
staticprotectedinherited

Definition at line 63 of file PlanNode.java.

PlanNodeId com.cloudera.impala.planner.PlanNode.id_
protectedinherited
DataPartition com.cloudera.impala.planner.SortNode.inputPartition_
private
boolean com.cloudera.impala.planner.SortNode.isAnalyticSort_
private
final Logger com.cloudera.impala.planner.SortNode.LOG = LoggerFactory.getLogger(SortNode.class)
staticprivate

Definition at line 48 of file SortNode.java.

Set<TupleId> com.cloudera.impala.planner.PlanNode.nullableTupleIds_ = Sets.newHashSet()
protectedinherited
List<Expr> com.cloudera.impala.planner.SortNode.resolvedTupleExprs_
private
ArrayList<TupleId> com.cloudera.impala.planner.PlanNode.tblRefIds_
protectedinherited

The documentation for this class was generated from the following file: