eckit::sql::expression::function::FunctionROWNUMBER 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

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

Public functions

auto type() const -> const eckit::sql::type::SQLType* override
auto clone() const -> std::shared_ptr<SQLExpression> override
void output(SQLOutput& s) const override
void preprepare(SQLSelect&) override
void updateType(SQLSelect& sql) 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

void print(std::ostream& s) const override
void prepare(SQLSelect&) override
void cleanup(SQLSelect&) override
auto isConstant() const -> bool override
void partialResult() override
auto eval(bool& missing) const -> double override
auto simplify(bool&) -> std::shared_ptr<SQLExpression> override
auto isAggregate() const -> bool override

Function documentation

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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