pub struct Merge { /* private fields */ }
Expand description
Merge zero or more expressions that ALL return structs.
If any field names are duplicated, the field from later expressions wins.
NOTE: Fields are not recursively merged, i.e. the later field REPLACES the earlier field. This makes struct fields behaviour consistent with other dtypes.
Implementations§
Source§impl Merge
impl Merge
pub fn new_expr(values: Vec<ExprRef>, nullability: Nullability) -> Arc<Self>
pub fn nullability(&self) -> Nullability
Trait Implementations§
Source§impl AnalysisExpr for Merge
impl AnalysisExpr for Merge
Source§fn stat_falsification(&self, _catalog: &mut dyn StatsCatalog) -> Option<ExprRef>
fn stat_falsification(&self, _catalog: &mut dyn StatsCatalog) -> Option<ExprRef>
An expression over zone-statistics which implies all records in the zone evaluate to false. Read more
Source§fn max(&self, _catalog: &mut dyn StatsCatalog) -> Option<ExprRef>
fn max(&self, _catalog: &mut dyn StatsCatalog) -> Option<ExprRef>
An expression for the upper non-null bound of this expression, if available. Read more
Source§fn min(&self, _catalog: &mut dyn StatsCatalog) -> Option<ExprRef>
fn min(&self, _catalog: &mut dyn StatsCatalog) -> Option<ExprRef>
An expression for the lower non-null bound of this expression, if available. Read more
fn field_path(&self) -> Option<AccessPath>
Source§impl VortexExpr for Merge
impl VortexExpr for Merge
Source§fn unchecked_evaluate(&self, ctx: &Scope) -> VortexResult<ArrayRef>
fn unchecked_evaluate(&self, ctx: &Scope) -> VortexResult<ArrayRef>
Compute result of expression on given batch producing a new batch Read more
fn children(&self) -> Vec<&ExprRef> ⓘ
fn replacing_children(self: Arc<Self>, children: Vec<ExprRef>) -> ExprRef
Source§fn return_dtype(&self, ctx: &ScopeDType) -> VortexResult<DType>
fn return_dtype(&self, ctx: &ScopeDType) -> VortexResult<DType>
Compute the type of the array returned by VortexExpr::evaluate.
impl Eq for Merge
impl StructuralPartialEq for Merge
Auto Trait Implementations§
impl Freeze for Merge
impl !RefUnwindSafe for Merge
impl Send for Merge
impl Sync for Merge
impl Unpin for Merge
impl !UnwindSafe for Merge
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<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.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