Skip to main content

Expr

Enum Expr 

Source
pub enum Expr {
    Column(String),
    Literal(Literal),
    BinaryOp {
        left: Box<Expr>,
        op: BinaryOperator,
        right: Box<Expr>,
    },
    UnaryOp {
        op: UnaryOperator,
        expr: Box<Expr>,
    },
    Function {
        name: String,
        args: Vec<Expr>,
    },
    Case {
        when_then: Vec<(Expr, Expr)>,
        else_expr: Option<Box<Expr>>,
    },
    Cast {
        expr: Box<Expr>,
        data_type: ExprDataType,
    },
    Coalesce {
        exprs: Vec<Expr>,
    },
}
Expand description

Represents an expression that can be used in a distributed computation

Variants§

§

Column(String)

Column reference

§

Literal(Literal)

Literal value

§

BinaryOp

Binary operation

Fields

§left: Box<Expr>

Left operand

§op: BinaryOperator

Operator

§right: Box<Expr>

Right operand

§

UnaryOp

Unary operation

Fields

§op: UnaryOperator

Operator

§expr: Box<Expr>

Operand

§

Function

Function call

Fields

§name: String

Function name

§args: Vec<Expr>

Arguments

§

Case

Case statement

Fields

§when_then: Vec<(Expr, Expr)>

When conditions and results

§else_expr: Option<Box<Expr>>

Default result

§

Cast

CAST expression

Fields

§expr: Box<Expr>

Input expression

§data_type: ExprDataType

Target data type

§

Coalesce

COALESCE expression

Fields

§exprs: Vec<Expr>

Expressions to check

Implementations§

Source§

impl Expr

Source

pub fn col(name: impl Into<String>) -> Self

Creates a column reference

Source

pub fn lit<T: Into<Literal>>(value: T) -> Self

Creates a literal value

Source

pub fn null() -> Self

Creates a literal NULL value

Source

pub fn call(name: impl Into<String>, args: Vec<Expr>) -> Self

Creates a function call

Source

pub fn binary(left: Expr, op: BinaryOperator, right: Expr) -> Self

Creates a binary operation

Source

pub fn unary(op: UnaryOperator, expr: Expr) -> Self

Creates a unary operation

Source

pub fn case(when_then: Vec<(Expr, Expr)>, else_expr: Option<Expr>) -> Self

Creates a CASE expression

Source

pub fn cast(expr: Expr, data_type: ExprDataType) -> Self

Creates a CAST expression

Source

pub fn coalesce(exprs: Vec<Expr>) -> Self

Creates a COALESCE expression

Source

pub fn add(self, other: Expr) -> Self

Adds two expressions

Source

pub fn sub(self, other: Expr) -> Self

Subtracts an expression from this one

Source

pub fn mul(self, other: Expr) -> Self

Multiplies this expression by another

Source

pub fn div(self, other: Expr) -> Self

Divides this expression by another

Source

pub fn modulo(self, other: Expr) -> Self

Applies modulo operation

Source

pub fn eq(self, other: Expr) -> Self

Checks if this expression equals another

Source

pub fn neq(self, other: Expr) -> Self

Checks if this expression does not equal another

Source

pub fn lt(self, other: Expr) -> Self

Checks if this expression is less than another

Source

pub fn lte(self, other: Expr) -> Self

Checks if this expression is less than or equal to another

Source

pub fn gt(self, other: Expr) -> Self

Checks if this expression is greater than another

Source

pub fn gte(self, other: Expr) -> Self

Checks if this expression is greater than or equal to another

Source

pub fn and(self, other: Expr) -> Self

Applies logical AND

Source

pub fn or(self, other: Expr) -> Self

Applies logical OR

Source

pub fn like(self, pattern: impl Into<String>) -> Self

Applies LIKE pattern matching

Source

pub fn concat(self, other: Expr) -> Self

Concatenates with another string expression

Source

pub fn negate(self) -> Self

Negates this expression

Source

pub fn not(self) -> Self

Applies logical NOT

Source

pub fn is_null(self) -> Self

Checks if this expression is NULL

Source

pub fn is_not_null(self) -> Self

Checks if this expression is NOT NULL

Source

pub fn to_boolean(self) -> Self

Casts this expression to boolean

Source

pub fn to_integer(self) -> Self

Casts this expression to integer

Source

pub fn to_float(self) -> Self

Casts this expression to float

Source

pub fn to_string(self) -> Self

Casts this expression to string

Source

pub fn to_date(self) -> Self

Casts this expression to date

Source

pub fn to_timestamp(self) -> Self

Casts this expression to timestamp

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<'de> Deserialize<'de> for Expr

Source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl Display for Expr

Source§

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

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

impl Serialize for Expr

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more

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> DisplayExt for T
where T: Display,

Source§

fn display_with_format(&self, format: &str) -> String

Displays the value with a specified format
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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
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> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. 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.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

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

Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,