30 QueryRewriter(
const std::vector<InputTableInfo>& query_infos, Executor* executor)
36 std::shared_ptr<Analyzer::ColumnVar> column_to_update)
const;
40 std::shared_ptr<Analyzer::ColumnVar> delete_column)
const;
51 const std::shared_ptr<Analyzer::CaseExpr>,
58 const std::list<std::shared_ptr<Analyzer::Expr>>& groupby_exprs)
const;
61 std::shared_ptr<Analyzer::Expr> expr)
const;
Defines data structures for the semantic analysis phase of query processing.
RelAlgExecutionUnit rewriteColumnarUpdate(const RelAlgExecutionUnit &ra_exe_unit_in, std::shared_ptr< Analyzer::ColumnVar > column_to_update) const
RelAlgExecutionUnit rewrite(const RelAlgExecutionUnit &ra_exe_unit_in) const
std::pair< bool, std::set< size_t > > is_all_groupby_exprs_are_col_var(const std::list< std::shared_ptr< Analyzer::Expr >> &groupby_exprs) const
const std::vector< InputTableInfo > & query_infos_
std::shared_ptr< Analyzer::CaseExpr > generateCaseExprForCountDistinctOnGroupByCol(std::shared_ptr< Analyzer::Expr > expr) const
RelAlgExecutionUnit rewriteColumnarDelete(const RelAlgExecutionUnit &ra_exe_unit_in, std::shared_ptr< Analyzer::ColumnVar > delete_column) const
QueryRewriter(const std::vector< InputTableInfo > &query_infos, Executor *executor)
static std::shared_ptr< Analyzer::CaseExpr > generateCaseForDomainValues(const Analyzer::InValues *)
RelAlgExecutionUnit rewriteConstrainedByIn(const RelAlgExecutionUnit &ra_exe_unit_in) const
RelAlgExecutionUnit rewriteAggregateOnGroupByColumn(const RelAlgExecutionUnit &ra_exe_unit_in) const
RelAlgExecutionUnit rewriteConstrainedByInImpl(const RelAlgExecutionUnit &ra_exe_unit_in, const std::shared_ptr< Analyzer::CaseExpr >, const Analyzer::InValues *) const
std::vector< std::shared_ptr< Analyzer::Expr > > target_exprs_owned_