pub enum ExprIr {
Show 22 variants
Column(String),
Lit(LiteralValue),
Eq(Box<ExprIr>, Box<ExprIr>),
Ne(Box<ExprIr>, Box<ExprIr>),
Gt(Box<ExprIr>, Box<ExprIr>),
Ge(Box<ExprIr>, Box<ExprIr>),
Lt(Box<ExprIr>, Box<ExprIr>),
Le(Box<ExprIr>, Box<ExprIr>),
EqNullSafe(Box<ExprIr>, Box<ExprIr>),
And(Box<ExprIr>, Box<ExprIr>),
Or(Box<ExprIr>, Box<ExprIr>),
Not(Box<ExprIr>),
Add(Box<ExprIr>, Box<ExprIr>),
Sub(Box<ExprIr>, Box<ExprIr>),
Mul(Box<ExprIr>, Box<ExprIr>),
Div(Box<ExprIr>, Box<ExprIr>),
Between {
left: Box<ExprIr>,
lower: Box<ExprIr>,
upper: Box<ExprIr>,
},
IsIn(Box<ExprIr>, Box<ExprIr>),
IsNull(Box<ExprIr>),
IsNotNull(Box<ExprIr>),
When {
condition: Box<ExprIr>,
then_expr: Box<ExprIr>,
otherwise: Box<ExprIr>,
},
Call {
name: String,
args: Vec<ExprIr>,
},
}Expand description
Expression IR: a single, serializable tree that backends convert to their native Expr.
Variants§
Column(String)
Column reference: col("name")
Lit(LiteralValue)
Literal value
Eq(Box<ExprIr>, Box<ExprIr>)
Ne(Box<ExprIr>, Box<ExprIr>)
Gt(Box<ExprIr>, Box<ExprIr>)
Ge(Box<ExprIr>, Box<ExprIr>)
Lt(Box<ExprIr>, Box<ExprIr>)
Le(Box<ExprIr>, Box<ExprIr>)
EqNullSafe(Box<ExprIr>, Box<ExprIr>)
And(Box<ExprIr>, Box<ExprIr>)
Or(Box<ExprIr>, Box<ExprIr>)
Not(Box<ExprIr>)
Add(Box<ExprIr>, Box<ExprIr>)
Sub(Box<ExprIr>, Box<ExprIr>)
Mul(Box<ExprIr>, Box<ExprIr>)
Div(Box<ExprIr>, Box<ExprIr>)
Between
IsIn(Box<ExprIr>, Box<ExprIr>)
IsNull(Box<ExprIr>)
IsNotNull(Box<ExprIr>)
When
Call
Function call: name and args (e.g. sum, count, upper, substring, cast).
Trait Implementations§
Source§impl<'de> Deserialize<'de> for ExprIr
impl<'de> Deserialize<'de> for ExprIr
Source§fn deserialize<__D>(
__deserializer: __D,
) -> Result<ExprIr, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(
__deserializer: __D,
) -> Result<ExprIr, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Source§impl Serialize for ExprIr
impl Serialize for ExprIr
Source§fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
Serialize this value into the given Serde serializer. Read more
Auto Trait Implementations§
impl Freeze for ExprIr
impl RefUnwindSafe for ExprIr
impl Send for ExprIr
impl Sync for ExprIr
impl Unpin for ExprIr
impl UnsafeUnpin for ExprIr
impl UnwindSafe for ExprIr
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
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 moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
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