Impala
Impalaistheopensource,nativeanalyticdatabaseforApacheHadoop.
|
Public Member Functions | |
AnalyticExpr (FunctionCallExpr fnCall, List< Expr > partitionExprs, List< OrderByElement > orderByElements, AnalyticWindow window) | |
FunctionCallExpr | getFnCall () |
List< Expr > | getPartitionExprs () |
List< OrderByElement > | getOrderByElements () |
AnalyticWindow | getWindow () |
boolean | equals (Object obj) |
boolean | isConstant () |
Expr | clone () |
String | toSqlImpl () |
String | debugString () |
void | analyze (Analyzer analyzer) throws AnalysisException |
ExprId | getId () |
Type | getType () |
double | getSelectivity () |
long | getNumDistinctValues () |
void | setPrintSqlInParens (boolean b) |
boolean | isWhereClauseConjunct () |
void | setIsWhereClauseConjunct () |
boolean | isAuxExpr () |
boolean | isRegisteredPredicate () |
void | setIsAuxExpr () |
Function | getFn () |
void | analyzeNoThrow (Analyzer analyzer) |
void | castChildCharsToStrings (Analyzer analyzer) throws AnalysisException |
String | toSql () |
TExpr | treeToThrift () |
boolean | isAggregate () |
List< String > | childrenToSql () |
int | hashCode () |
List< Expr > | getConjuncts () |
Expr | trySubstitute (ExprSubstitutionMap smap, Analyzer analyzer, boolean preserveRootType) throws AnalysisException |
Expr | substitute (ExprSubstitutionMap smap, Analyzer analyzer, boolean preserveRootType) |
Expr | reset () |
boolean | isBound (TupleId tid) |
boolean | isBound (SlotId slotId) |
boolean | isBoundByTupleIds (List< TupleId > tids) |
boolean | isBoundBySlotIds (List< SlotId > slotIds) |
void | getIds (List< TupleId > tupleIds, List< SlotId > slotIds) |
boolean | isLiteral () |
boolean | isNullLiteral () |
boolean | isScalarSubquery () |
void | checkReturnsBool (String name, boolean printExpr) throws AnalysisException |
final Expr | castTo (Type targetType) throws AnalysisException |
void | castChild (Type targetType, int childIndex) throws AnalysisException |
Expr | ignoreImplicitCast () |
boolean | isImplicitCast () |
String | toString () |
SlotRef | unwrapSlotRef (boolean implicitOnly) |
Expr | negate () |
Subquery | getSubquery () |
void | foldConstantChildren (Analyzer analyzer) throws AnalysisException |
Static Public Member Functions | |
static boolean | isAnalyticFn (Function fn) |
static boolean | isAggregateFn (Function fn) |
static long | getNumDistinctValues (List< Expr > exprs) |
static void | analyze (List<?extends Expr > exprs, Analyzer analyzer) throws AnalysisException |
static String | toSql (List<?extends Expr > exprs) |
static List< TExpr > | treesToThrift (List<?extends Expr > exprs) |
static com.google.common.base.Predicate < Expr > | isAggregatePredicate () |
static String | debugString (List<?extends Expr > exprs) |
static< CextendsExpr > boolean | equalLists (List< C > l1, List< C > l2) |
static< CextendsExpr > boolean | equalSets (List< C > l1, List< C > l2) |
static< CextendsExpr > boolean | isSubset (List< C > l1, List< C > l2) |
static< CextendsExpr > List< C > | intersect (List< C > l1, List< C > l2) |
static void | intersect (Analyzer analyzer, List< Expr > l1, List< Expr > l2, ExprSubstitutionMap smap, List< Expr > i1, List< Expr > i2) |
static ArrayList< Expr > | trySubstituteList (Iterable<?extends Expr > exprs, ExprSubstitutionMap smap, Analyzer analyzer, boolean preserveRootTypes) throws AnalysisException |
static ArrayList< Expr > | substituteList (Iterable<?extends Expr > exprs, ExprSubstitutionMap smap, Analyzer analyzer, boolean preserveRootTypes) |
static ArrayList< Expr > | resetList (ArrayList< Expr > l) |
static< CextendsExpr > ArrayList< C > | cloneList (Iterable< C > l) |
static< CextendsExpr > void | removeDuplicates (List< C > l) |
static< CextendsExpr > void | removeConstants (List< C > l) |
static boolean | isBound (List<?extends Expr > exprs, List< TupleId > tids) |
static< CextendsExpr > void | getIds (List<?extends Expr > exprs, List< TupleId > tupleIds, List< SlotId > slotIds) |
static Expr | pushNegationToOperands (Expr root) |
Static Public Attributes | |
static String | FIRST_VALUE_REWRITE = "first_value_rewrite" |
static final int | EXPR_CHILDREN_LIMIT = 10000 |
static final int | EXPR_DEPTH_LIMIT = 1000 |
static final com.google.common.base.Predicate < Expr > | IS_NOT_PREDICATE |
static final com.google.common.base.Predicate < Expr > | IS_OR_PREDICATE |
static final com.google.common.base.Predicate < Expr > | IS_SCALAR_SUBQUERY |
static final com.google.common.base.Predicate < Expr > | NON_NULL_EMPTY_AGG |
static final com.google.common.base.Predicate < Expr > | IS_BUILTIN_AGG_FN |
static final com.google.common.base.Predicate < Expr > | IS_TRUE_LITERAL |
Protected Member Functions | |
AnalyticExpr (AnalyticExpr other) | |
void | toThrift (TExprNode msg) |
void | resetAnalysisState () |
Expr | substituteImpl (ExprSubstitutionMap smap, Analyzer analyzer) throws AnalysisException |
void | setId (ExprId id) |
void | computeNumDistinctValues () |
Type[] | collectChildReturnTypes () |
Function | getBuiltinFunction (Analyzer analyzer, String name, Type[] argTypes, CompareMode mode) throws AnalysisException |
void | castForFunctionCall (boolean ignoreWildcardDecimals) throws AnalysisException |
void | convertNumericLiteralsFromDecimal (Analyzer analyzer) throws AnalysisException |
void | treeToThriftHelper (TExpr container) |
void | getIdsHelper (Set< TupleId > tupleIds, Set< SlotId > slotIds) |
Expr | uncheckedCastTo (Type targetType) throws AnalysisException |
void | uncheckedCastChild (Type targetType, int childIndex) throws AnalysisException |
Protected Attributes | |
ExprId | id_ |
Type | type_ |
boolean | isAnalyzed_ |
boolean | isWhereClauseConjunct_ |
boolean | printSqlInParens_ = false |
double | selectivity_ |
long | numDistinctValues_ |
Function | fn_ |
Static Protected Attributes | |
static double | DEFAULT_SELECTIVITY = 0.1 |
Package Functions | |
void | checkOffset (Analyzer analyzer) throws AnalysisException |
Type | getResolvedWildCardType () throws AnalysisException |
Private Member Functions | |
void | checkRangeOffsetBoundaryExpr (AnalyticWindow.Boundary boundary) throws AnalysisException |
void | standardize (Analyzer analyzer) |
Expr | getOffsetExpr (FunctionCallExpr offsetFnCall) |
void | syncWithChildren () |
void | setChildren () |
Static Private Member Functions | |
static boolean | isOffsetFn (Function fn) |
static boolean | isMinMax (Function fn) |
static boolean | isRankingFn (Function fn) |
Private Attributes | |
FunctionCallExpr | fnCall_ |
final List< Expr > | partitionExprs_ |
List< OrderByElement > | orderByElements_ = Lists.newArrayList() |
AnalyticWindow | window_ |
boolean | resetWindow_ = false |
String | sqlString_ |
Static Private Attributes | |
static final Logger | LOG = LoggerFactory.getLogger(AnalyticExpr.class) |
static String | LEAD = "lead" |
static String | LAG = "lag" |
static String | FIRSTVALUE = "first_value" |
static String | LASTVALUE = "last_value" |
static String | RANK = "rank" |
static String | DENSERANK = "dense_rank" |
static String | ROWNUMBER = "row_number" |
static String | MIN = "min" |
static String | MAX = "max" |
Representation of an analytic function call with OVER clause. All "subexpressions" (such as the actual function call parameters as well as the partition/ordering exprs, etc.) are embedded as children in order to allow expr substitution: function call params: child 0 .. #params partition exprs: children #params + 1 .. #params + #partition-exprs ordering exprs: children #params + #partition-exprs + 1 .. #params + #partition-exprs + #order-by-elements exprs in windowing clause: remaining children
Note that it's wrong to embed the FunctionCallExpr itself as a child, because in 'COUNT(..) OVER (..)' the 'COUNT(..)' is not part of a standard aggregate computation and must not be substituted as such. However, the parameters of the analytic function call might reference the output of an aggregate computation and need to be substituted as such; example: COUNT(COUNT(..)) OVER (..)
Definition at line 60 of file AnalyticExpr.java.
|
inline |
Definition at line 92 of file AnalyticExpr.java.
References com.cloudera.impala.analysis.AnalyticExpr.fnCall_, com.cloudera.impala.analysis.AnalyticExpr.partitionExprs_, com.cloudera.impala.analysis.AnalyticExpr.setChildren(), and com.cloudera.impala.analysis.AnalyticExpr.window_.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.clone(), com.cloudera.impala.analysis.AnalyticExpr.equals(), and com.cloudera.impala.analysis.AnalyticExpr.substituteImpl().
|
inlineprotected |
clone() c'tor
Definition at line 105 of file AnalyticExpr.java.
References com.cloudera.impala.analysis.FunctionCallExpr.clone(), com.cloudera.impala.analysis.AnalyticExpr.fnCall_, com.cloudera.impala.analysis.AnalyticExpr.orderByElements_, com.cloudera.impala.analysis.AnalyticExpr.partitionExprs_, com.cloudera.impala.analysis.AnalyticExpr.resetWindow_, com.cloudera.impala.analysis.AnalyticExpr.setChildren(), com.cloudera.impala.analysis.AnalyticExpr.sqlString_, and com.cloudera.impala.analysis.AnalyticExpr.window_.
|
inline |
Perform semantic analysis of node and all of its children. Throws exception if any errors found.
analyzer |
AnalysisException |
Implements com.cloudera.impala.analysis.ParseNode.
Definition at line 261 of file AnalyticExpr.java.
References com.cloudera.impala.analysis.AnalyticExpr.checkOffset(), com.cloudera.impala.analysis.AnalyticExpr.checkRangeOffsetBoundaryExpr(), com.cloudera.impala.analysis.AnalyticExpr.getFnCall(), com.cloudera.impala.analysis.AnalyticWindow.getLeftBoundary(), com.cloudera.impala.analysis.AnalyticWindow.getRightBoundary(), com.cloudera.impala.analysis.Expr.getType(), com.cloudera.impala.analysis.AnalyticExpr.isAggregateFn(), com.cloudera.impala.analysis.AnalyticExpr.isAnalyticFn(), com.cloudera.impala.analysis.Expr.isAnalyzed_, com.cloudera.impala.analysis.AnalyticExpr.isConstant(), com.cloudera.impala.analysis.AnalyticExpr.isMinMax(), com.cloudera.impala.analysis.AnalyticExpr.isOffsetFn(), com.cloudera.impala.analysis.AnalyticExpr.isRankingFn(), com.cloudera.impala.analysis.AnalyticExpr.orderByElements_, com.cloudera.impala.analysis.AnalyticExpr.partitionExprs_, com.cloudera.impala.analysis.AnalyticExpr.setChildren(), com.cloudera.impala.analysis.AnalyticExpr.sqlString_, com.cloudera.impala.analysis.AnalyticExpr.standardize(), com.cloudera.impala.analysis.Expr.toSql(), com.cloudera.impala.analysis.Expr.type_, com.cloudera.impala.analysis.AnalyticWindow.BoundaryType.UNBOUNDED_PRECEDING, and com.cloudera.impala.analysis.AnalyticExpr.window_.
|
inlinestaticinherited |
|
inlineinherited |
Helper function to analyze this expr and assert that the analysis was successful. TODO: This function could be used in many more places to clean up. Consider adding an IAnalyzable interface or similar to and move this helper into Analyzer such that non-Expr things can use the helper also.
Definition at line 238 of file Expr.java.
References com.cloudera.impala.analysis.Expr.analyze().
|
inlineinherited |
Add a cast expression above child. If child is a literal expression, we attempt to convert the value of the child directly, and not insert a cast node.
targetType | type to be cast to |
childIndex | index of child to be cast |
Definition at line 1008 of file Expr.java.
Referenced by com.cloudera.impala.analysis.CaseExpr.analyze(), and com.cloudera.impala.analysis.Expr.castForFunctionCall().
|
inlineinherited |
Casts any child which is CHAR to a STRING.
Definition at line 277 of file Expr.java.
References com.cloudera.impala.analysis.Expr.analyze(), com.cloudera.impala.analysis.Expr.castTo(), com.cloudera.impala.catalog.PrimitiveType.CHAR, and com.cloudera.impala.catalog.Type.STRING.
Referenced by com.cloudera.impala.analysis.CaseExpr.analyze().
|
inlineprotectedinherited |
Generates the necessary casts for the children of this expr to call fn_. child(0) is cast to the function's first argument, child(1) to the second etc. This does not do any validation and the casts are assumed to be safe.
If ignoreWildcardDecimals is true, the function will not cast arguments that are wildcard decimals. This is used for builtins where the cast is done within the BE function. Otherwise, if the function signature contains wildcard decimals, each wildcard child argument will be cast to the highest resolution that can contain all of the child wildcard arguments. e.g. fn(decimal(*), decimal(*)) called with fn(decimal(10,2), decimal(5,3)) both children will be cast to (11, 3).
Definition at line 312 of file Expr.java.
References com.cloudera.impala.analysis.Expr.castChild(), com.cloudera.impala.analysis.Expr.fn_, and com.cloudera.impala.analysis.Expr.getResolvedWildCardType().
Referenced by com.cloudera.impala.analysis.LikePredicate.analyze(), com.cloudera.impala.analysis.InPredicate.analyze(), com.cloudera.impala.analysis.TimestampArithmeticExpr.analyze(), com.cloudera.impala.analysis.CompoundPredicate.analyze(), com.cloudera.impala.analysis.ArithmeticExpr.analyze(), com.cloudera.impala.analysis.BinaryPredicate.analyze(), and com.cloudera.impala.analysis.FunctionCallExpr.analyze().
|
inlineinherited |
Casts this expr to a specific target type. It checks the validity of the cast and calls uncheckedCastTo().
targetType | type to be cast to |
AnalysisException | when an invalid cast is asked for, for example, failure to convert a string literal to a date literal |
Definition at line 967 of file Expr.java.
References com.cloudera.impala.analysis.Expr.type_, and com.cloudera.impala.analysis.Expr.uncheckedCastTo().
Referenced by com.cloudera.impala.analysis.Expr.castChildCharsToStrings().
|
inlinepackage |
Checks offset of lag()/lead().
Definition at line 236 of file AnalyticExpr.java.
References com.cloudera.impala.analysis.Expr.getFn(), com.cloudera.impala.analysis.AnalyticExpr.getFnCall(), com.cloudera.impala.util.TColumnValueUtil.getNumericVal(), com.cloudera.impala.analysis.AnalyticExpr.isOffsetFn(), offset, and com.cloudera.impala.analysis.Expr.toSql().
Referenced by com.cloudera.impala.analysis.AnalyticExpr.analyze().
|
inlineprivate |
Checks that the value expr of an offset boundary of a RANGE window is compatible with orderingExprs (and that there's only a single ordering expr).
Definition at line 215 of file AnalyticExpr.java.
References com.cloudera.impala.analysis.Expr.getType(), com.cloudera.impala.catalog.Type.isImplicitlyCastable(), com.cloudera.impala.analysis.AnalyticExpr.orderByElements_, and com.cloudera.impala.analysis.Expr.toSql().
Referenced by com.cloudera.impala.analysis.AnalyticExpr.analyze().
|
inlineinherited |
Checks whether this expr returns a boolean type or NULL type. If not, throws an AnalysisException with an appropriate error message using 'name' as a prefix. For example, 'name' could be "WHERE clause". The error message only contains this.toSql() if printExpr is true.
Definition at line 947 of file Expr.java.
References com.cloudera.impala.catalog.Type.isBoolean(), impala.name, com.cloudera.impala.analysis.Expr.toSql(), and com.cloudera.impala.analysis.Expr.type_.
|
inlineinherited |
Definition at line 531 of file Expr.java.
Referenced by com.cloudera.impala.analysis.FunctionCallExpr.toSqlImpl().
|
inline |
Definition at line 142 of file AnalyticExpr.java.
References com.cloudera.impala.analysis.AnalyticExpr.AnalyticExpr().
|
inlinestaticinherited |
Create a deep copy of 'l'. The elements of the returned list are of the same type as the input list.
Definition at line 798 of file Expr.java.
Referenced by com.cloudera.impala.planner.DistributedPlanner.createHashJoinFragment().
|
inlineprotectedinherited |
Collects the returns types of the child nodes in an array.
Definition at line 266 of file Expr.java.
References com.cloudera.impala.analysis.Expr.type_.
Referenced by com.cloudera.impala.analysis.IsNullPredicate.analyze(), com.cloudera.impala.analysis.LikePredicate.analyze(), com.cloudera.impala.analysis.TimestampArithmeticExpr.analyze(), com.cloudera.impala.analysis.CompoundPredicate.analyze(), com.cloudera.impala.analysis.ArithmeticExpr.analyze(), com.cloudera.impala.analysis.BinaryPredicate.analyze(), and com.cloudera.impala.analysis.FunctionCallExpr.analyze().
|
inlineprotectedinherited |
Definition at line 246 of file Expr.java.
References com.cloudera.impala.analysis.Expr.isConstant(), and com.cloudera.impala.analysis.Expr.numDistinctValues_.
Referenced by com.cloudera.impala.analysis.Expr.analyze(), and com.cloudera.impala.analysis.CastExpr.CastExpr().
|
inlineprotectedinherited |
Converts numeric literal in the expr tree rooted at this expr to return floating point types instead of decimals, if possible.
Decimal has a higher processing cost than floating point and we should not pay the cost if the user does not require the accuracy. For example: "select float_col + 1.1" would start out with 1.1 as a decimal(2,1) and the float_col would be promoted to a high accuracy decimal. This function will identify this case and treat 1.1 as a float. In the case of "decimal_col + 1.1", 1.1 would remain a decimal. In the case of "float_col + cast(1.1 as decimal(2,1))", the result would be a decimal.
Another way to think about it is that DecimalLiterals are analyzed as returning decimals (of the narrowest precision/scale) and we later convert them to a floating point type when it is consistent with the user's intent.
TODO: another option is to do constant folding in the FE and then apply this rule.
Definition at line 413 of file Expr.java.
References com.cloudera.impala.analysis.Expr.convertNumericLiteralsToFloat(), com.cloudera.impala.catalog.Type.isDecimal(), and com.cloudera.impala.analysis.Expr.isExplicitCastToDecimal().
Referenced by com.cloudera.impala.analysis.ArithmeticExpr.analyze(), and com.cloudera.impala.analysis.BinaryPredicate.analyze().
|
inline |
Definition at line 172 of file AnalyticExpr.java.
References com.cloudera.impala.analysis.AnalyticExpr.getFnCall(), and com.cloudera.impala.analysis.AnalyticExpr.window_.
|
inlinestaticinherited |
|
inlinestaticinherited |
Return true if l1[i].equals(l2[i]) for all i.
Definition at line 584 of file Expr.java.
Referenced by com.cloudera.impala.analysis.AggregateInfo.createDistinctAggInfo().
|
inline |
Definition at line 124 of file AnalyticExpr.java.
References com.cloudera.impala.analysis.AnalyticExpr.AnalyticExpr(), com.cloudera.impala.analysis.FunctionCallExpr.equals(), com.cloudera.impala.analysis.AnalyticWindow.equals(), com.cloudera.impala.analysis.AnalyticExpr.fnCall_, com.cloudera.impala.analysis.AnalyticExpr.getFnCall(), and com.cloudera.impala.analysis.AnalyticExpr.window_.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.isMinMax(), com.cloudera.impala.analysis.AnalyticExpr.isOffsetFn(), and com.cloudera.impala.analysis.AnalyticExpr.isRankingFn().
|
inlinestaticinherited |
Return true if l1 equals l2 when both lists are interpreted as sets. TODO: come up with something better than O(n^2)?
Definition at line 598 of file Expr.java.
Referenced by com.cloudera.impala.planner.AnalyticPlanner.WindowGroup.isCompatible(), and com.cloudera.impala.planner.AnalyticPlanner.SortGroup.isPrefixOf().
|
inlineinherited |
Evaluate in the BE the children of 'this' that are constant expressions and substitute them with the evaluation result as LiteralExprs. Modifies 'this' in place and does not re-analyze it. Hence, it is not safe to evaluate the modified expr in the BE as the resolved fn_ may be incorrect given the new arguments.
Throws an AnalysisException if the evaluation fails in the BE.
TODO: Used only during partition pruning. Convert it to a generic constant expression folding function to be used during the analysis.
Definition at line 1134 of file Expr.java.
References com.cloudera.impala.analysis.Expr.isAnalyzed_, and com.cloudera.impala.analysis.Expr.isLiteral().
|
inlineprotectedinherited |
Looks up in the catalog the builtin for 'name' and 'argTypes'. Returns null if the function is not found.
Definition at line 290 of file Expr.java.
References com.cloudera.impala.catalog.Catalog.BUILTINS_DB, com.cloudera.impala.catalog.Type.INVALID, and impala.name.
Referenced by com.cloudera.impala.analysis.IsNullPredicate.analyze(), com.cloudera.impala.analysis.LikePredicate.analyze(), com.cloudera.impala.analysis.InPredicate.analyze(), com.cloudera.impala.analysis.TimestampArithmeticExpr.analyze(), com.cloudera.impala.analysis.CompoundPredicate.analyze(), com.cloudera.impala.analysis.ArithmeticExpr.analyze(), com.cloudera.impala.analysis.BinaryPredicate.analyze(), and com.cloudera.impala.analysis.CaseExpr.analyze().
|
inlineinherited |
Gather conjuncts from this expr and return them in a list. A conjunct is an expr that returns a boolean, e.g., Predicates, function calls, SlotRefs, etc. Hence, this method is placed here and not in Predicate.
Definition at line 662 of file Expr.java.
Referenced by com.cloudera.impala.analysis.TableRef.analyzeJoin(), com.cloudera.impala.analysis.StmtRewriter.canEliminate(), com.cloudera.impala.analysis.StmtRewriter.mergeExpr(), com.cloudera.impala.analysis.Analyzer.registerConjuncts(), com.cloudera.impala.analysis.Analyzer.registerOnClauseConjuncts(), and com.cloudera.impala.analysis.StmtRewriter.rewriteWhereClauseSubqueries().
|
inlineinherited |
Definition at line 197 of file Expr.java.
References com.cloudera.impala.analysis.Expr.fn_.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.checkOffset(), com.cloudera.impala.analysis.AnalyticExpr.getOffsetExpr(), and com.cloudera.impala.analysis.AnalyticExpr.standardize().
|
inline |
Definition at line 118 of file AnalyticExpr.java.
References com.cloudera.impala.analysis.AnalyticExpr.fnCall_.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.analyze(), com.cloudera.impala.analysis.AnalyticExpr.checkOffset(), com.cloudera.impala.analysis.AnalyticExpr.debugString(), com.cloudera.impala.analysis.AnalyticExpr.equals(), com.cloudera.impala.analysis.AnalyticExpr.getOffsetExpr(), com.cloudera.impala.analysis.ColumnLineageGraph.getProjectionDeps(), and com.cloudera.impala.analysis.AnalyticExpr.standardize().
|
inlineinherited |
Definition at line 186 of file Expr.java.
References com.cloudera.impala.analysis.Expr.id_.
Referenced by com.cloudera.impala.analysis.Analyzer.canEvalPredicate(), com.cloudera.impala.analysis.Analyzer.getBoundPredicates(), com.cloudera.impala.analysis.SlotRef.getIdsHelper(), com.cloudera.impala.analysis.Analyzer.registerConjunct(), com.cloudera.impala.analysis.SlotRef.toString(), and com.cloudera.impala.analysis.SlotRef.toThrift().
|
inlineinherited |
Definition at line 883 of file Expr.java.
References com.cloudera.impala.analysis.Expr.getIdsHelper().
|
inlineprotectedinherited |
Definition at line 891 of file Expr.java.
Referenced by com.cloudera.impala.analysis.Expr.getIds().
|
inlineinherited |
Definition at line 190 of file Expr.java.
References com.cloudera.impala.analysis.Expr.numDistinctValues_.
Referenced by com.cloudera.impala.analysis.SlotRef.analyze(), com.cloudera.impala.analysis.BinaryPredicate.analyze(), and com.cloudera.impala.analysis.SlotRef.SlotRef().
|
inlinestaticinherited |
|
inlineprivate |
Returns the explicit or implicit offset of an analytic function call.
Definition at line 542 of file AnalyticExpr.java.
References com.cloudera.impala.analysis.Expr.getFn(), com.cloudera.impala.analysis.AnalyticExpr.getFnCall(), and com.cloudera.impala.analysis.AnalyticExpr.isOffsetFn().
Referenced by com.cloudera.impala.analysis.AnalyticExpr.standardize().
|
inline |
Definition at line 120 of file AnalyticExpr.java.
References com.cloudera.impala.analysis.AnalyticExpr.orderByElements_.
Referenced by com.cloudera.impala.analysis.ColumnLineageGraph.getPredicateDeps(), and com.cloudera.impala.planner.AnalyticPlanner.WindowGroup.isCompatible().
|
inline |
Definition at line 119 of file AnalyticExpr.java.
References com.cloudera.impala.analysis.AnalyticExpr.partitionExprs_.
Referenced by com.cloudera.impala.planner.AnalyticPlanner.WindowGroup.isCompatible().
|
inlinepackageinherited |
Returns the max resolution type of all the wild card decimal types. Returns null if there are no wild card types.
Definition at line 336 of file Expr.java.
References com.cloudera.impala.catalog.Type.isNull(), com.cloudera.impala.catalog.Type.isWildcardDecimal(), and com.cloudera.impala.analysis.Expr.type_.
Referenced by com.cloudera.impala.analysis.Expr.castForFunctionCall().
|
inlineinherited |
Definition at line 189 of file Expr.java.
References com.cloudera.impala.analysis.Expr.selectivity_.
|
inlineinherited |
|
inlineinherited |
Definition at line 188 of file Expr.java.
References com.cloudera.impala.analysis.Expr.type_.
Referenced by com.cloudera.impala.analysis.Subquery.analyze(), com.cloudera.impala.analysis.IsNullPredicate.analyze(), com.cloudera.impala.analysis.LimitElement.analyze(), com.cloudera.impala.analysis.InPredicate.analyze(), com.cloudera.impala.analysis.TimestampArithmeticExpr.analyze(), com.cloudera.impala.analysis.BinaryPredicate.analyze(), com.cloudera.impala.analysis.CastExpr.analyze(), com.cloudera.impala.analysis.CaseExpr.analyze(), com.cloudera.impala.analysis.AnalyticExpr.analyze(), com.cloudera.impala.analysis.FunctionCallExpr.analyze(), com.cloudera.impala.analysis.AnalyzeExprsTest.checkCasts(), com.cloudera.impala.analysis.AnalyticInfo.checkConsistency(), com.cloudera.impala.analysis.AggregateInfo.checkConsistency(), com.cloudera.impala.analysis.AnalyticWindow.checkOffsetBoundaries(), com.cloudera.impala.analysis.AnalyticExpr.checkRangeOffsetBoundaryExpr(), com.cloudera.impala.analysis.Subquery.createStructTypeFromExprList(), com.cloudera.impala.analysis.InlineViewRef.createTupleDescriptor(), com.cloudera.impala.catalog.ColumnStats.fromExpr(), com.cloudera.impala.planner.DataSourceScanNode.getDisjunctsHelper(), com.cloudera.impala.analysis.Expr.isExplicitCastToDecimal(), com.cloudera.impala.analysis.Expr.isScalarSubquery(), com.cloudera.impala.planner.DataSourceScanNode.literalToColumnValue(), com.cloudera.impala.analysis.Subquery.returnsScalarColumn(), com.cloudera.impala.analysis.QueryStmt.substituteOrdinals(), com.cloudera.impala.analysis.Expr.trySubstitute(), and com.cloudera.impala.analysis.AnalyzeExprsTest.typeCastTest().
|
inline |
Definition at line 121 of file AnalyticExpr.java.
References com.cloudera.impala.analysis.AnalyticExpr.window_.
|
inlineinherited |
Definition at line 649 of file Expr.java.
References com.cloudera.impala.analysis.Expr.id_.
|
inlineinherited |
Returns child expr if this expr is an implicit cast, otherwise returns 'this'.
Definition at line 1034 of file Expr.java.
References com.cloudera.impala.analysis.Expr.isImplicitCast().
|
inlinestaticinherited |
|
inlinestaticinherited |
Compute the intersection of l1 and l2, given the smap, and return the intersecting l1 elements in i1 and the intersecting l2 elements in i2.
Definition at line 626 of file Expr.java.
References com.cloudera.impala.analysis.Expr.equals().
|
inlineinherited |
|
inlinestatic |
Definition at line 189 of file AnalyticExpr.java.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.analyze().
|
inlinestaticinherited |
Definition at line 523 of file Expr.java.
References com.cloudera.impala.analysis.Expr.isAggregatePredicate_.
Referenced by com.cloudera.impala.analysis.SelectStmt.analyze(), com.cloudera.impala.analysis.FunctionCallExpr.analyze(), com.cloudera.impala.analysis.SelectStmt.analyzeAggregation(), and com.cloudera.impala.analysis.TableRef.analyzeJoin().
|
inlinestatic |
|
inlineinherited |
Definition at line 194 of file Expr.java.
References com.cloudera.impala.analysis.Expr.isAuxExpr_.
Referenced by com.cloudera.impala.analysis.Analyzer.hasUnassignedConjuncts().
|
inlineinherited |
Returns true if expr is fully bound by tid, otherwise false.
Definition at line 845 of file Expr.java.
References com.cloudera.impala.analysis.Expr.isBoundByTupleIds().
Referenced by com.cloudera.impala.analysis.SelectStmt.analyzeAggregation().
|
inlineinherited |
Returns true if expr is fully bound by slotId, otherwise false.
Definition at line 862 of file Expr.java.
References com.cloudera.impala.analysis.Expr.isBoundBySlotIds().
|
inlineinherited |
Returns true if expr is fully bound by slotIds, otherwise false.
Definition at line 869 of file Expr.java.
Referenced by com.cloudera.impala.analysis.Expr.isBound(), and com.cloudera.impala.planner.HdfsScanNode.prunePartitions().
|
inlineinherited |
Returns true if expr is fully bound by tids, otherwise false.
Definition at line 852 of file Expr.java.
Referenced by com.cloudera.impala.analysis.Analyzer.canEvalPredicate(), com.cloudera.impala.planner.AnalyticPlanner.createSortInfo(), com.cloudera.impala.analysis.Expr.isBound(), and com.cloudera.impala.analysis.StmtRewriter.mergeExpr().
|
inline |
Analytic exprs cannot be constant.
Definition at line 139 of file AnalyticExpr.java.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.analyze().
|
inlineinherited |
Returns true if 'this' is an implicit cast expr.
Definition at line 1042 of file Expr.java.
Referenced by com.cloudera.impala.analysis.Expr.ignoreImplicitCast(), com.cloudera.impala.analysis.Expr.reset(), and com.cloudera.impala.analysis.Expr.substituteImpl().
|
inlineinherited |
Definition at line 908 of file Expr.java.
Referenced by com.cloudera.impala.planner.HdfsScanNode.canEvalUsingPartitionMd(), com.cloudera.impala.analysis.CaseExpr.CaseExpr(), and com.cloudera.impala.analysis.Expr.foldConstantChildren().
|
inlinestaticprivate |
Definition at line 199 of file AnalyticExpr.java.
References com.cloudera.impala.analysis.AnalyticExpr.equals(), com.cloudera.impala.analysis.AnalyticExpr.isAnalyticFn(), com.cloudera.impala.analysis.AnalyticExpr.MAX, and com.cloudera.impala.analysis.AnalyticExpr.MIN.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.analyze().
|
inlineinherited |
Definition at line 926 of file Expr.java.
Referenced by com.cloudera.impala.analysis.CaseExpr.CaseExpr().
|
inlinestaticprivate |
Definition at line 194 of file AnalyticExpr.java.
References com.cloudera.impala.analysis.AnalyticExpr.equals(), com.cloudera.impala.analysis.AnalyticExpr.isAnalyticFn(), com.cloudera.impala.analysis.AnalyticExpr.LAG, and com.cloudera.impala.analysis.AnalyticExpr.LEAD.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.analyze(), com.cloudera.impala.analysis.AnalyticExpr.checkOffset(), com.cloudera.impala.analysis.AnalyticExpr.getOffsetExpr(), and com.cloudera.impala.analysis.AnalyticExpr.standardize().
|
inlinestaticprivate |
Definition at line 204 of file AnalyticExpr.java.
References com.cloudera.impala.analysis.AnalyticExpr.DENSERANK, com.cloudera.impala.analysis.AnalyticExpr.equals(), com.cloudera.impala.analysis.AnalyticExpr.isAnalyticFn(), com.cloudera.impala.analysis.AnalyticExpr.RANK, and com.cloudera.impala.analysis.AnalyticExpr.ROWNUMBER.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.analyze().
|
inlineinherited |
Definition at line 195 of file Expr.java.
References com.cloudera.impala.analysis.Expr.id_.
Referenced by com.cloudera.impala.planner.SingleNodePlanner.migrateConjunctsToInlineView().
|
inlineinherited |
Return true if this expr is a scalar subquery.
Definition at line 936 of file Expr.java.
References com.cloudera.impala.analysis.Expr.getType(), and com.cloudera.impala.analysis.Expr.isAnalyzed_.
Referenced by com.cloudera.impala.analysis.StmtRewriter.createJoinConjunct().
|
inlinestaticinherited |
Return true if l1 is a subset of l2.
Definition at line 606 of file Expr.java.
Referenced by com.cloudera.impala.planner.DistributedPlanner.createInsertFragment().
|
inlineinherited |
Definition at line 192 of file Expr.java.
References com.cloudera.impala.analysis.Expr.isWhereClauseConjunct_.
Referenced by com.cloudera.impala.analysis.Analyzer.canEvalPredicate(), and com.cloudera.impala.analysis.Analyzer.evalByJoin().
|
inlineinherited |
Negates a boolean Expr.
Definition at line 1102 of file Expr.java.
References com.cloudera.impala.catalog.PrimitiveType.BOOLEAN.
|
inlinestaticinherited |
Pushes negation to the individual operands of a predicate tree rooted at 'root'.
Definition at line 1076 of file Expr.java.
References com.cloudera.impala.analysis.Expr.IS_NOT_PREDICATE, and com.cloudera.impala.analysis.Expr.NEGATE_FN.
|
inlinestaticinherited |
|
inlinestaticinherited |
|
inlineinherited |
Resets the internal analysis state of this expr tree. Removes implicit casts.
Definition at line 771 of file Expr.java.
References com.cloudera.impala.analysis.Expr.isImplicitCast(), and com.cloudera.impala.analysis.Expr.resetAnalysisState().
Referenced by com.cloudera.impala.analysis.Expr.resetList().
|
inlineprotected |
Definition at line 588 of file AnalyticExpr.java.
References com.cloudera.impala.analysis.AnalyticExpr.resetWindow_, com.cloudera.impala.analysis.AnalyticExpr.syncWithChildren(), and com.cloudera.impala.analysis.AnalyticExpr.window_.
|
inlinestaticinherited |
Definition at line 780 of file Expr.java.
References com.cloudera.impala.analysis.Expr.reset().
|
inlineprivate |
Populate children_ from fnCall_, partitionExprs_, orderByElements_
Definition at line 569 of file AnalyticExpr.java.
References com.cloudera.impala.analysis.AnalyticExpr.fnCall_, com.cloudera.impala.analysis.AnalyticWindow.getLeftBoundary(), com.cloudera.impala.analysis.AnalyticWindow.getRightBoundary(), com.cloudera.impala.analysis.AnalyticExpr.orderByElements_, com.cloudera.impala.analysis.AnalyticExpr.partitionExprs_, and com.cloudera.impala.analysis.AnalyticExpr.window_.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.AnalyticExpr(), and com.cloudera.impala.analysis.AnalyticExpr.analyze().
|
inlineprotectedinherited |
|
inlineinherited |
Definition at line 196 of file Expr.java.
References com.cloudera.impala.analysis.Expr.isAuxExpr_.
|
inlineinherited |
Definition at line 193 of file Expr.java.
References com.cloudera.impala.analysis.Expr.isWhereClauseConjunct_.
|
inlineinherited |
Definition at line 191 of file Expr.java.
References com.cloudera.impala.analysis.Expr.printSqlInParens_.
|
inlineprivate |
If necessary, rewrites the analytic function, window, and/or order-by elements into a standard format for the purpose of simpler backend execution, as follows:
Definition at line 404 of file AnalyticExpr.java.
References com.cloudera.impala.catalog.Type.BIGINT, com.cloudera.impala.analysis.AnalyticWindow.BoundaryType.CURRENT_ROW, com.cloudera.impala.analysis.AnalyticWindow.DEFAULT_WINDOW, com.cloudera.impala.analysis.AnalyticExpr.FIRSTVALUE, com.cloudera.impala.analysis.AnalyticExpr.fnCall_, com.cloudera.impala.analysis.AnalyticWindow.BoundaryType.FOLLOWING, com.cloudera.impala.analysis.Expr.getFn(), com.cloudera.impala.analysis.AnalyticExpr.getFnCall(), com.cloudera.impala.analysis.FunctionName.getFunction(), com.cloudera.impala.analysis.AnalyticWindow.getLeftBoundary(), com.cloudera.impala.analysis.AnalyticExpr.getOffsetExpr(), com.cloudera.impala.analysis.AnalyticWindow.getRightBoundary(), com.cloudera.impala.analysis.AnalyticWindow.getType(), com.cloudera.impala.analysis.AnalyticExpr.isOffsetFn(), com.cloudera.impala.analysis.AnalyticExpr.LAG, com.cloudera.impala.analysis.AnalyticExpr.LASTVALUE, com.cloudera.impala.analysis.AnalyticExpr.orderByElements_, com.cloudera.impala.analysis.AnalyticWindow.BoundaryType.PRECEDING, com.cloudera.impala.analysis.AnalyticExpr.resetWindow_, com.cloudera.impala.analysis.AnalyticExpr.ROWNUMBER, com.cloudera.impala.analysis.Expr.type_, com.cloudera.impala.analysis.AnalyticWindow.BoundaryType.UNBOUNDED_FOLLOWING, com.cloudera.impala.analysis.AnalyticWindow.BoundaryType.UNBOUNDED_PRECEDING, and com.cloudera.impala.analysis.AnalyticExpr.window_.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.analyze().
|
inlineinherited |
Returns an analyzed clone of 'this' with exprs substituted according to smap. Removes implicit casts and analysis state while cloning/substituting exprs within this tree, such that the returned result has minimal implicit casts and types. Expects the analysis of the post-substitution expr to succeed. If smap is null, this function is equivalent to clone(). If preserveRootType is true, the resulting expr tree will be cast if necessary to the type of 'this'.
Definition at line 710 of file Expr.java.
References com.cloudera.impala.analysis.Expr.trySubstitute().
Referenced by com.cloudera.impala.planner.HashJoinNode.init().
|
inlineprotected |
Definition at line 598 of file AnalyticExpr.java.
References com.cloudera.impala.analysis.AnalyticExpr.AnalyticExpr().
|
inlinestaticinherited |
Definition at line 730 of file Expr.java.
References com.cloudera.impala.analysis.Expr.trySubstituteList().
Referenced by com.cloudera.impala.planner.AnalyticPlanner.createSortGroupPlan(), and com.cloudera.impala.planner.AnalyticPlanner.createSortInfo().
|
inlineprivate |
Keep fnCall_, partitionExprs_ and orderByElements_ in sync with children_.
Definition at line 552 of file AnalyticExpr.java.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.resetAnalysisState().
|
inlineinherited |
Implements com.cloudera.impala.analysis.ParseNode.
Definition at line 449 of file Expr.java.
References com.cloudera.impala.analysis.Expr.printSqlInParens_, and com.cloudera.impala.analysis.Expr.toSqlImpl().
Referenced by com.cloudera.impala.analysis.ExtractFromExpr.analyze(), com.cloudera.impala.analysis.Subquery.analyze(), com.cloudera.impala.analysis.SlotRef.analyze(), com.cloudera.impala.analysis.LimitElement.analyze(), com.cloudera.impala.analysis.LikePredicate.analyze(), com.cloudera.impala.analysis.InPredicate.analyze(), com.cloudera.impala.analysis.TimestampArithmeticExpr.analyze(), com.cloudera.impala.analysis.CompoundPredicate.analyze(), com.cloudera.impala.analysis.ArithmeticExpr.analyze(), com.cloudera.impala.analysis.BinaryPredicate.analyze(), com.cloudera.impala.analysis.NumericLiteral.analyze(), com.cloudera.impala.analysis.Expr.analyze(), com.cloudera.impala.analysis.CastExpr.analyze(), com.cloudera.impala.analysis.CaseExpr.analyze(), com.cloudera.impala.analysis.AnalyticExpr.analyze(), com.cloudera.impala.analysis.FunctionCallExpr.analyze(), com.cloudera.impala.analysis.SelectStmt.analyzeAggregation(), com.cloudera.impala.analysis.AnalyticExpr.checkOffset(), com.cloudera.impala.analysis.AnalyticExpr.checkRangeOffsetBoundaryExpr(), com.cloudera.impala.analysis.Expr.checkReturnsBool(), com.cloudera.impala.analysis.LiteralExpr.create(), com.cloudera.impala.analysis.StmtRewriter.createJoinConjunct(), com.cloudera.impala.analysis.QueryStmt.createSortInfo(), com.cloudera.impala.analysis.ExtractFromExpr.getFunctionNotFoundError(), com.cloudera.impala.analysis.FunctionCallExpr.getFunctionNotFoundError(), com.cloudera.impala.analysis.Analyzer.registerConjunct(), com.cloudera.impala.analysis.QueryStmt.substituteOrdinals(), com.cloudera.impala.analysis.CaseExpr.toCaseSql(), com.cloudera.impala.analysis.TableRef.toSql(), com.cloudera.impala.analysis.BetweenPredicate.toSqlImpl(), and com.cloudera.impala.analysis.AnalyticExpr.toSqlImpl().
|
inlinestaticinherited |
|
inline |
Definition at line 145 of file AnalyticExpr.java.
References com.cloudera.impala.analysis.AnalyticExpr.orderByElements_, com.cloudera.impala.analysis.AnalyticExpr.partitionExprs_, com.cloudera.impala.analysis.AnalyticExpr.sqlString_, com.cloudera.impala.analysis.Expr.toSql(), and com.cloudera.impala.analysis.AnalyticExpr.window_.
|
inlineinherited |
Definition at line 1047 of file Expr.java.
References com.cloudera.impala.analysis.Expr.id_, com.cloudera.impala.analysis.Expr.numDistinctValues_, com.cloudera.impala.analysis.Expr.selectivity_, and com.cloudera.impala.analysis.Expr.type_.
Referenced by com.cloudera.impala.analysis.ExtractFromExpr.analyze(), com.cloudera.impala.analysis.NullLiteral.debugString(), com.cloudera.impala.analysis.NumericLiteral.debugString(), com.cloudera.impala.analysis.CastExpr.debugString(), com.cloudera.impala.analysis.CastExpr.getFnName(), and com.cloudera.impala.analysis.InPredicate.initBuiltins().
|
inlineprotected |
Definition at line 181 of file AnalyticExpr.java.
|
inlinestaticinherited |
Definition at line 515 of file Expr.java.
Referenced by com.cloudera.impala.planner.HdfsTableSink.toThrift(), com.cloudera.impala.planner.SortNode.toThrift(), and com.cloudera.impala.planner.ExchangeNode.toThrift().
|
inlineinherited |
Definition at line 460 of file Expr.java.
References com.cloudera.impala.catalog.Type.BOOLEAN, com.cloudera.impala.catalog.Type.isNull(), com.cloudera.impala.analysis.Expr.treeToThriftHelper(), and com.cloudera.impala.analysis.Expr.type_.
|
inlineprotectedinherited |
Definition at line 474 of file Expr.java.
References com.cloudera.impala.analysis.Expr.fn_, com.cloudera.impala.catalog.Function.getNumArgs(), com.cloudera.impala.catalog.Function.hasVarArgs(), com.cloudera.impala.analysis.Expr.isAnalyzed_, and com.cloudera.impala.analysis.Expr.toThrift().
Referenced by com.cloudera.impala.analysis.Expr.treeToThrift().
|
inlineinherited |
Returns an analyzed clone of 'this' with exprs substituted according to smap. Removes implicit casts and analysis state while cloning/substituting exprs within this tree, such that the returned result has minimal implicit casts and types. Throws if analyzing the post-substitution expr tree failed. If smap is null, this function is equivalent to clone(). If preserveRootType is true, the resulting expr tree will be cast if necessary to the type of 'this'.
Definition at line 689 of file Expr.java.
References com.cloudera.impala.analysis.Expr.clone(), com.cloudera.impala.analysis.Expr.getType(), and com.cloudera.impala.analysis.Expr.type_.
Referenced by com.cloudera.impala.analysis.Expr.substitute().
|
inlinestaticinherited |
Definition at line 719 of file Expr.java.
Referenced by com.cloudera.impala.analysis.Expr.substituteList().
|
inlineprotectedinherited |
Convert child to to targetType, possibly by inserting an implicit cast, or by returning an altogether new expression, or by returning 'this' with a modified return type'.
targetType | type to be cast to |
childIndex | index of child to be cast |
Definition at line 1024 of file Expr.java.
Referenced by com.cloudera.impala.analysis.IsNullPredicate.analyze(), com.cloudera.impala.analysis.InPredicate.analyze(), com.cloudera.impala.analysis.CastExpr.analyze(), and com.cloudera.impala.analysis.FunctionCallExpr.analyze().
|
inlineprotectedinherited |
Create an expression equivalent to 'this' but returning targetType; possibly by inserting an implicit cast, or by returning an altogether new expression or by returning 'this' with a modified return type'.
targetType | type to be cast to |
AnalysisException | when an invalid cast is asked for, for example, failure to convert a string literal to a date literal |
Definition at line 995 of file Expr.java.
Referenced by com.cloudera.impala.analysis.Expr.castTo().
|
inlineinherited |
|
staticprotectedinherited |
Definition at line 63 of file Expr.java.
Referenced by com.cloudera.impala.analysis.BetweenPredicate.analyze(), com.cloudera.impala.analysis.SlotRef.analyze(), com.cloudera.impala.analysis.IsNullPredicate.analyze(), com.cloudera.impala.analysis.InPredicate.analyze(), and com.cloudera.impala.analysis.BinaryPredicate.analyze().
|
staticprivate |
Definition at line 83 of file AnalyticExpr.java.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.isRankingFn().
|
staticinherited |
Definition at line 54 of file Expr.java.
Referenced by com.cloudera.impala.analysis.Expr.analyze(), and com.cloudera.impala.analysis.AnalyzeExprsTest.TestExprChildLimit().
|
staticinherited |
Definition at line 56 of file Expr.java.
Referenced by com.cloudera.impala.analysis.Expr.analyze(), com.cloudera.impala.analysis.AnalyzeExprsTest.testFuncExprDepthLimit(), and com.cloudera.impala.analysis.AnalyzeExprsTest.testInfixExprDepthLimit().
|
static |
Definition at line 90 of file AnalyticExpr.java.
Referenced by com.cloudera.impala.planner.AnalyticPlanner.WindowGroup.requiresIndependentEval().
|
staticprivate |
Definition at line 80 of file AnalyticExpr.java.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.standardize().
|
protectedinherited |
Definition at line 161 of file Expr.java.
Referenced by com.cloudera.impala.analysis.BetweenPredicate.analyze(), com.cloudera.impala.analysis.IsNullPredicate.analyze(), com.cloudera.impala.analysis.LikePredicate.analyze(), com.cloudera.impala.analysis.InPredicate.analyze(), com.cloudera.impala.analysis.TimestampArithmeticExpr.analyze(), com.cloudera.impala.analysis.CompoundPredicate.analyze(), com.cloudera.impala.analysis.ArithmeticExpr.analyze(), com.cloudera.impala.analysis.BinaryPredicate.analyze(), com.cloudera.impala.analysis.CastExpr.analyze(), com.cloudera.impala.analysis.CaseExpr.analyze(), com.cloudera.impala.analysis.FunctionCallExpr.analyze(), com.cloudera.impala.analysis.Expr.castForFunctionCall(), com.cloudera.impala.analysis.Expr.equals(), com.cloudera.impala.analysis.Expr.Expr(), com.cloudera.impala.analysis.Expr.getFn(), com.cloudera.impala.analysis.FunctionCallExpr.getReturnType(), com.cloudera.impala.analysis.FunctionCallExpr.isAggregateFunction(), com.cloudera.impala.analysis.FunctionCallExpr.isConstant(), com.cloudera.impala.analysis.FunctionCallExpr.isScalarFunction(), com.cloudera.impala.analysis.FunctionCallExpr.resetAnalysisState(), com.cloudera.impala.analysis.FunctionCallExpr.returnsNonNullOnEmpty(), and com.cloudera.impala.analysis.Expr.treeToThriftHelper().
|
private |
Definition at line 63 of file AnalyticExpr.java.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.AnalyticExpr(), com.cloudera.impala.analysis.AnalyticExpr.equals(), com.cloudera.impala.analysis.AnalyticExpr.getFnCall(), com.cloudera.impala.analysis.AnalyticExpr.setChildren(), and com.cloudera.impala.analysis.AnalyticExpr.standardize().
|
protectedinherited |
Definition at line 135 of file Expr.java.
Referenced by com.cloudera.impala.analysis.Expr.debugString(), com.cloudera.impala.analysis.Expr.Expr(), com.cloudera.impala.analysis.Expr.getId(), com.cloudera.impala.analysis.Expr.hashCode(), com.cloudera.impala.analysis.Expr.isRegisteredPredicate(), and com.cloudera.impala.analysis.Expr.toString().
|
staticinherited |
Definition at line 115 of file Expr.java.
Referenced by com.cloudera.impala.analysis.StmtRewriter.createJoinConjunct().
|
staticinherited |
Definition at line 75 of file Expr.java.
Referenced by com.cloudera.impala.analysis.Expr.pushNegationToOperands().
|
staticinherited |
Definition at line 85 of file Expr.java.
Referenced by com.cloudera.impala.analysis.StmtRewriter.canExtractCorrelatedPredicates(), and com.cloudera.impala.analysis.StmtRewriter.hasSubqueryInDisjunction().
|
staticinherited |
Definition at line 95 of file Expr.java.
Referenced by com.cloudera.impala.analysis.IsNullPredicate.analyze(), and com.cloudera.impala.analysis.StmtRewriter.rewriteWhereClauseSubqueries().
|
staticinherited |
Definition at line 124 of file Expr.java.
Referenced by com.cloudera.impala.analysis.StmtRewriter.canEliminate().
|
protectedinherited |
Definition at line 143 of file Expr.java.
Referenced by com.cloudera.impala.analysis.Predicate< com.cloudera.impala.analysis.Expr >.analyze(), com.cloudera.impala.analysis.ExistsPredicate.analyze(), com.cloudera.impala.analysis.TupleIsNullPredicate.analyze(), com.cloudera.impala.analysis.ExtractFromExpr.analyze(), com.cloudera.impala.analysis.BetweenPredicate.analyze(), com.cloudera.impala.analysis.Subquery.analyze(), com.cloudera.impala.analysis.SlotRef.analyze(), com.cloudera.impala.analysis.IsNullPredicate.analyze(), com.cloudera.impala.analysis.LikePredicate.analyze(), com.cloudera.impala.analysis.InPredicate.analyze(), com.cloudera.impala.analysis.TimestampArithmeticExpr.analyze(), com.cloudera.impala.analysis.CompoundPredicate.analyze(), com.cloudera.impala.analysis.ArithmeticExpr.analyze(), com.cloudera.impala.analysis.BinaryPredicate.analyze(), com.cloudera.impala.analysis.NumericLiteral.analyze(), com.cloudera.impala.analysis.CastExpr.analyze(), com.cloudera.impala.analysis.Expr.analyze(), com.cloudera.impala.analysis.CaseExpr.analyze(), com.cloudera.impala.analysis.AnalyticExpr.analyze(), com.cloudera.impala.analysis.FunctionCallExpr.analyze(), com.cloudera.impala.analysis.CastExpr.CastExpr(), com.cloudera.impala.analysis.Expr.Expr(), com.cloudera.impala.analysis.Expr.foldConstantChildren(), com.cloudera.impala.analysis.SlotRef.getDesc(), com.cloudera.impala.analysis.SlotRef.getResolvedPath(), com.cloudera.impala.analysis.BetweenPredicate.getRewrittenPredicate(), com.cloudera.impala.analysis.SlotRef.getSlotId(), com.cloudera.impala.analysis.NumericLiteral.init(), com.cloudera.impala.analysis.SlotRef.isBoundBySlotIds(), com.cloudera.impala.analysis.Expr.isScalarSubquery(), com.cloudera.impala.analysis.NumericLiteral.NumericLiteral(), com.cloudera.impala.analysis.FunctionCallExpr.resetAnalysisState(), com.cloudera.impala.analysis.Expr.resetAnalysisState(), com.cloudera.impala.analysis.SlotRef.SlotRef(), com.cloudera.impala.analysis.Subquery.Subquery(), com.cloudera.impala.analysis.Expr.treeToThriftHelper(), and com.cloudera.impala.analysis.NumericLiteral.uncheckedCastTo().
|
protectedinherited |
|
staticprivate |
Definition at line 79 of file AnalyticExpr.java.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.isOffsetFn(), and com.cloudera.impala.analysis.AnalyticExpr.standardize().
|
staticprivate |
Definition at line 81 of file AnalyticExpr.java.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.standardize().
|
staticprivate |
Definition at line 78 of file AnalyticExpr.java.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.isOffsetFn().
|
staticprivate |
Definition at line 61 of file AnalyticExpr.java.
|
staticprivate |
Definition at line 86 of file AnalyticExpr.java.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.isMinMax().
|
staticprivate |
Definition at line 85 of file AnalyticExpr.java.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.isMinMax().
|
staticinherited |
Definition at line 106 of file Expr.java.
Referenced by com.cloudera.impala.analysis.StmtRewriter.createJoinConjunct(), and com.cloudera.impala.analysis.StmtRewriter.mergeExpr().
|
protectedinherited |
Definition at line 157 of file Expr.java.
Referenced by com.cloudera.impala.analysis.Predicate< com.cloudera.impala.analysis.Expr >.analyze(), com.cloudera.impala.analysis.SlotRef.analyze(), com.cloudera.impala.analysis.Expr.computeNumDistinctValues(), com.cloudera.impala.analysis.Expr.Expr(), com.cloudera.impala.analysis.Expr.getNumDistinctValues(), com.cloudera.impala.analysis.LiteralExpr.LiteralExpr(), com.cloudera.impala.analysis.SlotRef.SlotRef(), and com.cloudera.impala.analysis.Expr.toString().
|
private |
Definition at line 67 of file AnalyticExpr.java.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.AnalyticExpr(), com.cloudera.impala.analysis.AnalyticExpr.analyze(), com.cloudera.impala.analysis.AnalyticExpr.checkRangeOffsetBoundaryExpr(), com.cloudera.impala.analysis.AnalyticExpr.getOrderByElements(), com.cloudera.impala.analysis.AnalyticExpr.setChildren(), com.cloudera.impala.analysis.AnalyticExpr.standardize(), and com.cloudera.impala.analysis.AnalyticExpr.toSqlImpl().
|
private |
Definition at line 64 of file AnalyticExpr.java.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.AnalyticExpr(), com.cloudera.impala.analysis.AnalyticExpr.analyze(), com.cloudera.impala.analysis.AnalyticExpr.getPartitionExprs(), com.cloudera.impala.analysis.AnalyticExpr.setChildren(), and com.cloudera.impala.analysis.AnalyticExpr.toSqlImpl().
|
protectedinherited |
Definition at line 148 of file Expr.java.
Referenced by com.cloudera.impala.analysis.Expr.Expr(), com.cloudera.impala.analysis.Expr.setPrintSqlInParens(), and com.cloudera.impala.analysis.Expr.toSql().
|
staticprivate |
Definition at line 82 of file AnalyticExpr.java.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.isRankingFn().
|
private |
Definition at line 73 of file AnalyticExpr.java.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.AnalyticExpr(), com.cloudera.impala.analysis.AnalyticExpr.resetAnalysisState(), and com.cloudera.impala.analysis.AnalyticExpr.standardize().
|
staticprivate |
Definition at line 84 of file AnalyticExpr.java.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.isRankingFn(), and com.cloudera.impala.analysis.AnalyticExpr.standardize().
|
protectedinherited |
Definition at line 153 of file Expr.java.
Referenced by com.cloudera.impala.analysis.BetweenPredicate.analyze(), com.cloudera.impala.analysis.SlotRef.analyze(), com.cloudera.impala.analysis.IsNullPredicate.analyze(), com.cloudera.impala.analysis.InPredicate.analyze(), com.cloudera.impala.analysis.CompoundPredicate.analyze(), com.cloudera.impala.analysis.BinaryPredicate.analyze(), com.cloudera.impala.analysis.Expr.Expr(), com.cloudera.impala.analysis.Expr.getSelectivity(), com.cloudera.impala.analysis.LikePredicate.LikePredicate(), and com.cloudera.impala.analysis.Expr.toString().
|
private |
Definition at line 76 of file AnalyticExpr.java.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.AnalyticExpr(), com.cloudera.impala.analysis.AnalyticExpr.analyze(), and com.cloudera.impala.analysis.AnalyticExpr.toSqlImpl().
|
protectedinherited |
Definition at line 142 of file Expr.java.
Referenced by com.cloudera.impala.analysis.Predicate< com.cloudera.impala.analysis.Expr >.analyze(), com.cloudera.impala.analysis.Subquery.analyze(), com.cloudera.impala.analysis.SlotRef.analyze(), com.cloudera.impala.analysis.TimestampArithmeticExpr.analyze(), com.cloudera.impala.analysis.ArithmeticExpr.analyze(), com.cloudera.impala.analysis.NumericLiteral.analyze(), com.cloudera.impala.analysis.CastExpr.analyze(), com.cloudera.impala.analysis.CaseExpr.analyze(), com.cloudera.impala.analysis.AnalyticExpr.analyze(), com.cloudera.impala.analysis.FunctionCallExpr.analyze(), com.cloudera.impala.analysis.BoolLiteral.BoolLiteral(), com.cloudera.impala.analysis.CastExpr.CastExpr(), com.cloudera.impala.analysis.Expr.castTo(), com.cloudera.impala.analysis.Expr.checkReturnsBool(), com.cloudera.impala.analysis.Expr.collectChildReturnTypes(), com.cloudera.impala.analysis.NumericLiteral.debugString(), com.cloudera.impala.analysis.CastExpr.debugString(), com.cloudera.impala.analysis.NumericLiteral.explicitlyCastToFloat(), com.cloudera.impala.analysis.Expr.Expr(), com.cloudera.impala.analysis.ExtractFromExpr.ExtractFromExpr(), com.cloudera.impala.analysis.Expr.getResolvedWildCardType(), com.cloudera.impala.analysis.Expr.getType(), com.cloudera.impala.analysis.NumericLiteral.getUnscaledValue(), com.cloudera.impala.analysis.NullLiteral.NullLiteral(), com.cloudera.impala.analysis.NumericLiteral.NumericLiteral(), com.cloudera.impala.analysis.NullLiteral.resetAnalysisState(), com.cloudera.impala.analysis.SlotRef.SlotRef(), com.cloudera.impala.analysis.AnalyticExpr.standardize(), com.cloudera.impala.analysis.StringLiteral.StringLiteral(), com.cloudera.impala.analysis.Expr.toString(), com.cloudera.impala.analysis.NumericLiteral.toThrift(), com.cloudera.impala.analysis.Expr.treeToThrift(), com.cloudera.impala.analysis.Expr.trySubstitute(), com.cloudera.impala.analysis.NullLiteral.uncheckedCastTo(), com.cloudera.impala.analysis.StringLiteral.uncheckedCastTo(), com.cloudera.impala.analysis.NumericLiteral.uncheckedCastTo(), and com.cloudera.impala.analysis.SlotRef.uncheckedCastTo().
|
private |
Definition at line 68 of file AnalyticExpr.java.
Referenced by com.cloudera.impala.analysis.AnalyticExpr.AnalyticExpr(), com.cloudera.impala.analysis.AnalyticExpr.analyze(), com.cloudera.impala.analysis.AnalyticExpr.debugString(), com.cloudera.impala.analysis.AnalyticExpr.equals(), com.cloudera.impala.analysis.AnalyticExpr.getWindow(), com.cloudera.impala.analysis.AnalyticExpr.resetAnalysisState(), com.cloudera.impala.analysis.AnalyticExpr.setChildren(), com.cloudera.impala.analysis.AnalyticExpr.standardize(), and com.cloudera.impala.analysis.AnalyticExpr.toSqlImpl().