eckit::sql::expression::function::FunctionAND class

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

FunctionAND(const std::string&, const expression::Expressions&)
FunctionAND(const FunctionAND&)
~FunctionAND()

Public functions

auto clone() const -> std::shared_ptr<SQLExpression> override
void print(std::ostream& s) const override
void preprepare(SQLSelect&) override
void prepare(SQLSelect& sql) override
void updateType(SQLSelect& sql) override
void cleanup(SQLSelect& sql) override
auto isConstant() const -> bool override
auto isAggregate() const -> bool override
void partialResult() 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 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
auto eval(bool& missing) const -> double override
auto simplify(bool&) -> std::shared_ptr<SQLExpression> override
auto andSplit(expression::Expressions&) -> bool override

Function documentation

static std::shared_ptr<SQLExpression> eckit::sql::expression::function::FunctionAND::number(double)

void eckit::sql::expression::function::FunctionAND::print(std::ostream& s) const override

void eckit::sql::expression::function::FunctionAND::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::FunctionAND::prepare(SQLSelect& sql) override

void eckit::sql::expression::function::FunctionAND::updateType(SQLSelect& sql) override

void eckit::sql::expression::function::FunctionAND::cleanup(SQLSelect& sql) override

bool eckit::sql::expression::function::FunctionAND::isConstant() const override

bool eckit::sql::expression::function::FunctionAND::isAggregate() const override

void eckit::sql::expression::function::FunctionAND::partialResult() override

std::shared_ptr<SQLExpression> eckit::sql::expression::function::FunctionAND::reshift(int minColumnShift) const override

expression::Expressions& eckit::sql::expression::function::FunctionAND::args()

void eckit::sql::expression::function::FunctionAND::eval(double* out, bool& missing) const virtual

std::string eckit::sql::expression::function::FunctionAND::evalAsString(bool& missing) const virtual

bool eckit::sql::expression::function::FunctionAND::isNumber() const virtual

void eckit::sql::expression::function::FunctionAND::title(const std::string&) virtual

std::string eckit::sql::expression::function::FunctionAND::title() const virtual

void eckit::sql::expression::function::FunctionAND::output(SQLOutput&) const virtual

void eckit::sql::expression::function::FunctionAND::expandStars(const std::vector<std::reference_wrapper<const SQLTable>>&, expression::Expressions&) virtual

bool eckit::sql::expression::function::FunctionAND::isBitfield() const virtual

BitfieldDef eckit::sql::expression::function::FunctionAND::bitfieldDef() const

bool eckit::sql::expression::function::FunctionAND::hasMissingValue() const virtual

double eckit::sql::expression::function::FunctionAND::missingValue() const

This website is beyond its original expiry date and the content may be out of date. The site owner has been notified and may choose to extend the expiry date and remove this banner. If you have any questions about this, please visit our support portal.