class
FunctionSUM
Base classes
- class FunctionExpression
Public static functions
- static auto arity() -> int
- static auto help() -> const char*
-
static auto number(double) -> std::
shared_ptr<SQLExpression>
Constructors, destructors, conversion operators
-
FunctionSUM(const std::
string&, const expression:: Expressions&) - FunctionSUM(const FunctionSUM&)
- ~FunctionSUM()
Public functions
-
auto clone() const -> std::
shared_ptr<SQLExpression> override -
void print(std::
ostream& s) const override - void preprepare(SQLSelect&) override
- void updateType(SQLSelect& sql) override
- auto isConstant() const -> bool override
-
auto simplify(bool&) -> std::
shared_ptr<SQLExpression> override -
auto reshift(int minColumnShift) const -> std::
shared_ptr<SQLExpression> override -
auto args() -> expression::
Expressions& - void eval(double* out, bool& missing) const virtual
-
auto evalAsString(bool& missing) const -> std::
string virtual -
auto andSplit(expression::
Expressions&) -> bool virtual - auto isNumber() const -> bool virtual
-
void title(const std::
string&) virtual -
auto title() const -> std::
string virtual - void output(SQLOutput&) const virtual
-
void expandStars(const std::
vector<std:: reference_wrapper<const SQLTable>>&, expression:: Expressions&) virtual - auto isBitfield() const -> bool virtual
- auto bitfieldDef() const -> BitfieldDef
- auto hasMissingValue() const -> bool virtual
- auto missingValue() const -> double
- auto shared_from_this(T... args) -> T
- auto weak_from_this(T... args) -> T
Private functions
-
auto type() const -> const eckit::
sql:: type:: SQLType* override - void prepare(SQLSelect&) override
- void cleanup(SQLSelect&) override
- void partialResult() override
- auto eval(bool& missing) const -> double override
- auto isAggregate() const -> bool override
Function documentation
static const char* eckit:: sql:: expression:: function:: FunctionSUM:: help()
static std:: shared_ptr<SQLExpression> eckit:: sql:: expression:: function:: FunctionSUM:: number(double)
void eckit:: sql:: expression:: function:: FunctionSUM:: print(std:: ostream& s) const override
void eckit:: sql:: expression:: function:: FunctionSUM:: preprepare(SQLSelect&) override
pre-prepare ideally wouldn't exist. To enable a two-pass prepare of SQL columns for SQLSelect, this is here.
void eckit:: sql:: expression:: function:: FunctionSUM:: updateType(SQLSelect& sql) override
bool eckit:: sql:: expression:: function:: FunctionSUM:: isConstant() const override
std:: shared_ptr<SQLExpression> eckit:: sql:: expression:: function:: FunctionSUM:: simplify(bool&) override
std:: shared_ptr<SQLExpression> eckit:: sql:: expression:: function:: FunctionSUM:: reshift(int minColumnShift) const override
expression:: Expressions& eckit:: sql:: expression:: function:: FunctionSUM:: args()
void eckit:: sql:: expression:: function:: FunctionSUM:: eval(double* out,
bool& missing) const virtual
std:: string eckit:: sql:: expression:: function:: FunctionSUM:: evalAsString(bool& missing) const virtual
bool eckit:: sql:: expression:: function:: FunctionSUM:: andSplit(expression:: Expressions&) virtual
bool eckit:: sql:: expression:: function:: FunctionSUM:: isNumber() const virtual
void eckit:: sql:: expression:: function:: FunctionSUM:: title(const std:: string&) virtual
std:: string eckit:: sql:: expression:: function:: FunctionSUM:: title() const virtual
void eckit:: sql:: expression:: function:: FunctionSUM:: expandStars(const std:: vector<std:: reference_wrapper<const SQLTable>>&,
expression:: Expressions&) virtual
bool eckit:: sql:: expression:: function:: FunctionSUM:: isBitfield() const virtual
BitfieldDef eckit:: sql:: expression:: function:: FunctionSUM:: bitfieldDef() const
bool eckit:: sql:: expression:: function:: FunctionSUM:: hasMissingValue() const virtual
double eckit:: sql:: expression:: function:: FunctionSUM:: missingValue() const