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>
If an expression is returned, its value is an upper bound on the value of 
expr. Read moreSource§fn min(&self, _catalog: &mut dyn StatsCatalog) -> Option<ExprRef>
 
fn min(&self, _catalog: &mut dyn StatsCatalog) -> Option<ExprRef>
If an expression is returned, its value is an upper bound on the value of 
expr.
see AnalysisExpr::maxfn 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