eckit::sql::expression::function::FunctionTIMESTAMP class

Base classes

class FunctionIntegerExpression

Public static functions

static auto arity() -> int
static void registerIntegerFunctions()
static auto help() -> const char*
static auto number(double) -> std::shared_ptr<SQLExpression>

Constructors, destructors, conversion operators

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

Public functions

auto clone() const -> std::shared_ptr<SQLExpression> override
auto type() const -> const eckit::sql::type::SQLType* override
void output(SQLOutput& s) const 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 simplify(bool&) -> std::shared_ptr<SQLExpression> 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 andSplit(expression::Expressions&) -> bool virtual
auto isNumber() const -> bool virtual
void title(const std::string&) virtual
auto title() const -> std::string 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 eval(bool& missing) const -> double override

Function documentation

static void eckit::sql::expression::function::FunctionTIMESTAMP::registerIntegerFunctions()

static const char* eckit::sql::expression::function::FunctionTIMESTAMP::help()

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

void eckit::sql::expression::function::FunctionTIMESTAMP::output(SQLOutput& s) const override

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

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

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

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

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

std::shared_ptr<SQLExpression> eckit::sql::expression::function::FunctionTIMESTAMP::simplify(bool&) override

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

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

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

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

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

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

bool eckit::sql::expression::function::FunctionTIMESTAMP::andSplit(expression::Expressions&) virtual

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

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

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

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

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

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

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

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