Skip to main content

Expr

Enum Expr 

Source
pub enum Expr {
Show 17 variants Column(usize), Const(ConstValue), Compare { left: Box<Expr>, op: CompareOp, right: Box<Expr>, }, And(Vec<Expr>), Or(Vec<Expr>), Not(Box<Expr>), Add(Box<Expr>, Box<Expr>), Sub(Box<Expr>, Box<Expr>), Mul(Box<Expr>, Box<Expr>), Div(Box<Expr>, Box<Expr>), Mod(Box<Expr>, Box<Expr>), Abs(Box<Expr>), Min(Box<Expr>, Box<Expr>), Max(Box<Expr>, Box<Expr>), Pow(Box<Expr>, Box<Expr>), Cast(Box<Expr>, ScalarType), Conditional { condition: Box<Expr>, then_expr: Box<Expr>, else_expr: Box<Expr>, },
}
Expand description

Expression in filter predicates

Variants§

§

Column(usize)

Column reference by index

§

Const(ConstValue)

Constant value

§

Compare

Binary comparison

Fields

§left: Box<Expr>

Left-hand side expression.

§op: CompareOp

Comparison operator.

§right: Box<Expr>

Right-hand side expression.

§

And(Vec<Expr>)

Logical AND

§

Or(Vec<Expr>)

Logical OR

§

Not(Box<Expr>)

Logical NOT

§

Add(Box<Expr>, Box<Expr>)

Addition

§

Sub(Box<Expr>, Box<Expr>)

Subtraction

§

Mul(Box<Expr>, Box<Expr>)

Multiplication

§

Div(Box<Expr>, Box<Expr>)

Division

§

Mod(Box<Expr>, Box<Expr>)

Modulo

§

Abs(Box<Expr>)

Absolute value

§

Min(Box<Expr>, Box<Expr>)

Minimum of two values

§

Max(Box<Expr>, Box<Expr>)

Maximum of two values

§

Pow(Box<Expr>, Box<Expr>)

Power (base, exponent)

§

Cast(Box<Expr>, ScalarType)

Type cast

§

Conditional

Conditional expression: if condition then then_expr else else_expr The condition is a boolean comparison expression. Used for UDF conditionals like: if X >= 100 then 1 else 2

Fields

§condition: Box<Expr>

Boolean condition (should evaluate to bool)

§then_expr: Box<Expr>

Expression to evaluate when condition is true

§else_expr: Box<Expr>

Expression to evaluate when condition is false

Trait Implementations§

Source§

impl Clone for Expr

Source§

fn clone(&self) -> Expr

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for Expr

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl PartialEq for Expr

Source§

fn eq(&self, other: &Expr) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl StructuralPartialEq for Expr

Auto Trait Implementations§

§

impl Freeze for Expr

§

impl RefUnwindSafe for Expr

§

impl Send for Expr

§

impl Sync for Expr

§

impl Unpin for Expr

§

impl UnsafeUnpin for Expr

§

impl UnwindSafe for Expr

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<T> Allocation for T
where T: RefUnwindSafe + Send + Sync,