OmniSciDB
a5dc49c757
|
#include <Analyzer.h>
Public Member Functions | |
AggExpr (const SQLTypeInfo &ti, SQLAgg a, std::shared_ptr< Analyzer::Expr > g, bool d, std::shared_ptr< Analyzer::Expr > e) | |
AggExpr (SQLTypes t, SQLAgg a, Expr *g, bool d, std::shared_ptr< Analyzer::Expr > e, int idx) | |
SQLAgg | get_aggtype () const |
Expr * | get_arg () const |
std::shared_ptr< Analyzer::Expr > | get_own_arg () const |
bool | get_is_distinct () const |
std::shared_ptr< Analyzer::Expr > | get_arg1 () const |
std::shared_ptr< Analyzer::Expr > | deep_copy () const override |
void | group_predicates (std::list< const Expr * > &scan_predicates, std::list< const Expr * > &join_predicates, std::list< const Expr * > &const_predicates) const override |
void | collect_rte_idx (std::set< int > &rte_idx_set) const override |
void | collect_column_var (std::set< const ColumnVar *, bool(*)(const ColumnVar *, const ColumnVar *)> &colvar_set, bool include_agg) const override |
std::shared_ptr< Analyzer::Expr > | rewrite_with_targetlist (const std::vector< std::shared_ptr< TargetEntry >> &tlist) const override |
std::shared_ptr< Analyzer::Expr > | rewrite_with_child_targetlist (const std::vector< std::shared_ptr< TargetEntry >> &tlist) const override |
std::shared_ptr< Analyzer::Expr > | rewrite_agg_to_var (const std::vector< std::shared_ptr< TargetEntry >> &tlist) const override |
bool | operator== (const Expr &rhs) const override |
std::string | toString () const override |
void | find_expr (std::function< bool(const Expr *)> f, std::list< const Expr * > &expr_list) const override |
Public Member Functions inherited from Analyzer::Expr | |
Expr (SQLTypes t, bool notnull) | |
Expr (SQLTypes t, int d, bool notnull) | |
Expr (SQLTypes t, int d, int s, bool notnull) | |
Expr (const SQLTypeInfo &ti, bool has_agg=false) | |
virtual | ~Expr () |
std::shared_ptr< Analyzer::Expr > | get_shared_ptr () |
const SQLTypeInfo & | get_type_info () const |
void | set_type_info (const SQLTypeInfo &ti) |
bool | get_contains_agg () const |
void | set_contains_agg (bool a) |
virtual std::shared_ptr < Analyzer::Expr > | add_cast (const SQLTypeInfo &new_type_info) |
virtual void | check_group_by (const std::list< std::shared_ptr< Analyzer::Expr >> &groupby) const |
virtual std::shared_ptr < Analyzer::Expr > | normalize_simple_predicate (int &rte_idx) const |
virtual size_t | get_num_column_vars (const bool include_agg) const |
virtual void | print () const |
virtual void | add_unique (std::list< const Expr * > &expr_list) const |
std::shared_ptr< Analyzer::Expr > | decompress () |
virtual void | get_domain (DomainSet &domain_set) const |
Private Attributes | |
SQLAgg | aggtype |
std::shared_ptr< Analyzer::Expr > | arg |
bool | is_distinct |
std::shared_ptr< Analyzer::Expr > | arg1 |
Additional Inherited Members | |
Protected Attributes inherited from Analyzer::Expr | |
SQLTypeInfo | type_info |
bool | contains_agg |
Definition at line 1310 of file Analyzer.h.
|
inline |
Definition at line 1312 of file Analyzer.h.
|
inline |
Definition at line 1318 of file Analyzer.h.
|
inlineoverridevirtual |
|
inlineoverridevirtual |
|
overridevirtual |
Implements Analyzer::Expr.
Definition at line 194 of file Analyzer.cpp.
References aggtype, arg, arg1, is_distinct, and Analyzer::Expr::type_info.
Referenced by rewrite_with_targetlist().
|
overridevirtual |
Reimplemented from Analyzer::Expr.
Definition at line 3405 of file Analyzer.cpp.
References Analyzer::Expr::add_unique(), arg, and f().
|
inline |
Definition at line 1329 of file Analyzer.h.
References aggtype.
Referenced by anonymous_namespace{SerializeToSql.cpp}::agg_to_string(), anonymous_namespace{RelAlgExecutor.cpp}::is_agg(), operator==(), and DeepCopyVisitor::visitAggExpr().
|
inline |
Definition at line 1330 of file Analyzer.h.
References arg.
Referenced by agg_arg(), anonymous_namespace{SerializeToSql.cpp}::agg_to_string(), GroupByAndAggregate::gpuCanHandleOrderEntries(), anonymous_namespace{GroupByAndAggregate.cpp}::init_count_distinct_descriptors(), operator==(), DeepCopyVisitor::visitAggExpr(), and ScalarExprVisitor< std::set< shared::TableKey > >::visitAggExpr().
|
inline |
Definition at line 1333 of file Analyzer.h.
References arg1.
Referenced by DeepCopyVisitor::visitAggExpr().
|
inline |
Definition at line 1332 of file Analyzer.h.
References is_distinct.
Referenced by anonymous_namespace{SerializeToSql.cpp}::agg_to_string(), anonymous_namespace{RelAlgExecutor.cpp}::is_count_distinct(), operator==(), and DeepCopyVisitor::visitAggExpr().
|
inline |
|
overridevirtual |
|
overridevirtual |
Implements Analyzer::Expr.
Definition at line 2560 of file Analyzer.cpp.
References aggtype, arg, get_aggtype(), get_arg(), get_is_distinct(), and is_distinct.
|
overridevirtual |
Reimplemented from Analyzer::Expr.
Definition at line 2117 of file Analyzer.cpp.
References Analyzer::Expr::get_type_info(), and Analyzer::Var::kINPUT_OUTER.
|
overridevirtual |
Reimplemented from Analyzer::Expr.
Definition at line 2108 of file Analyzer.cpp.
References aggtype, arg, arg1, is_distinct, and Analyzer::Expr::type_info.
|
overridevirtual |
Reimplemented from Analyzer::Expr.
Definition at line 2094 of file Analyzer.cpp.
References deep_copy().
|
overridevirtual |
Implements Analyzer::Expr.
Definition at line 3015 of file Analyzer.cpp.
References aggtype, arg, is_distinct, kAPPROX_COUNT_DISTINCT, kAPPROX_QUANTILE, kAVG, kCOUNT, kCOUNT_IF, kMAX, kMIN, kMODE, kSAMPLE, kSINGLE_VALUE, kSUM, kSUM_IF, and UNREACHABLE.
|
private |
Definition at line 1363 of file Analyzer.h.
Referenced by deep_copy(), get_aggtype(), operator==(), rewrite_with_child_targetlist(), and toString().
|
private |
Definition at line 1364 of file Analyzer.h.
Referenced by collect_column_var(), collect_rte_idx(), deep_copy(), find_expr(), get_arg(), get_own_arg(), group_predicates(), operator==(), rewrite_with_child_targetlist(), and toString().
|
private |
Definition at line 1367 of file Analyzer.h.
Referenced by deep_copy(), get_arg1(), and rewrite_with_child_targetlist().
|
private |
Definition at line 1365 of file Analyzer.h.
Referenced by deep_copy(), get_is_distinct(), operator==(), heavydb.serialized_result_set.ttypes.TTargetInfo::read(), rewrite_with_child_targetlist(), toString(), and heavydb.serialized_result_set.ttypes.TTargetInfo::write().