pub struct GetIndexedFieldExpr { /* private fields */ }
Expand description
Expression to get a field of a struct array.
Implementations§
source§impl GetIndexedFieldExpr
impl GetIndexedFieldExpr
sourcepub fn new(arg: Arc<dyn PhysicalExpr>, field: GetFieldAccessExpr) -> Self
pub fn new(arg: Arc<dyn PhysicalExpr>, field: GetFieldAccessExpr) -> Self
Create new GetIndexedFieldExpr
sourcepub fn new_field(arg: Arc<dyn PhysicalExpr>, name: impl Into<String>) -> Self
pub fn new_field(arg: Arc<dyn PhysicalExpr>, name: impl Into<String>) -> Self
Create a new GetIndexedFieldExpr
for accessing the named field
sourcepub fn new_index(arg: Arc<dyn PhysicalExpr>, key: Arc<dyn PhysicalExpr>) -> Self
pub fn new_index(arg: Arc<dyn PhysicalExpr>, key: Arc<dyn PhysicalExpr>) -> Self
Create a new GetIndexedFieldExpr
for accessing the specified index
sourcepub fn new_range(
arg: Arc<dyn PhysicalExpr>,
start: Arc<dyn PhysicalExpr>,
stop: Arc<dyn PhysicalExpr>
) -> Self
pub fn new_range( arg: Arc<dyn PhysicalExpr>, start: Arc<dyn PhysicalExpr>, stop: Arc<dyn PhysicalExpr> ) -> Self
Create a new GetIndexedFieldExpr
for accessing the range
sourcepub fn field(&self) -> &GetFieldAccessExpr
pub fn field(&self) -> &GetFieldAccessExpr
Get the description of what field should be accessed
sourcepub fn arg(&self) -> &Arc<dyn PhysicalExpr>
pub fn arg(&self) -> &Arc<dyn PhysicalExpr>
Get the input expression
Trait Implementations§
source§impl Debug for GetIndexedFieldExpr
impl Debug for GetIndexedFieldExpr
source§impl Display for GetIndexedFieldExpr
impl Display for GetIndexedFieldExpr
source§impl Hash for GetIndexedFieldExpr
impl Hash for GetIndexedFieldExpr
source§impl PartialEq<dyn Any> for GetIndexedFieldExpr
impl PartialEq<dyn Any> for GetIndexedFieldExpr
source§impl PhysicalExpr for GetIndexedFieldExpr
impl PhysicalExpr for GetIndexedFieldExpr
source§fn as_any(&self) -> &dyn Any
fn as_any(&self) -> &dyn Any
Returns the physical expression as
Any
so that it can be
downcast to a specific implementation.source§fn data_type(&self, input_schema: &Schema) -> Result<DataType>
fn data_type(&self, input_schema: &Schema) -> Result<DataType>
Get the data type of this expression, given the schema of the input
source§fn nullable(&self, input_schema: &Schema) -> Result<bool>
fn nullable(&self, input_schema: &Schema) -> Result<bool>
Determine whether this expression is nullable, given the schema of the input
source§fn evaluate(&self, batch: &RecordBatch) -> Result<ColumnarValue>
fn evaluate(&self, batch: &RecordBatch) -> Result<ColumnarValue>
Evaluate an expression against a RecordBatch
source§fn children(&self) -> Vec<Arc<dyn PhysicalExpr>>
fn children(&self) -> Vec<Arc<dyn PhysicalExpr>>
Get a list of child PhysicalExpr that provide the input for this expr.
source§fn with_new_children(
self: Arc<Self>,
children: Vec<Arc<dyn PhysicalExpr>>
) -> Result<Arc<dyn PhysicalExpr>>
fn with_new_children( self: Arc<Self>, children: Vec<Arc<dyn PhysicalExpr>> ) -> Result<Arc<dyn PhysicalExpr>>
Returns a new PhysicalExpr where all children were replaced by new exprs.
source§fn evaluate_selection(
&self,
batch: &RecordBatch,
selection: &BooleanArray
) -> Result<ColumnarValue>
fn evaluate_selection( &self, batch: &RecordBatch, selection: &BooleanArray ) -> Result<ColumnarValue>
Evaluate an expression against a RecordBatch after first applying a
validity array
source§fn evaluate_bounds(&self, _children: &[&Interval]) -> Result<Interval>
fn evaluate_bounds(&self, _children: &[&Interval]) -> Result<Interval>
Computes bounds for the expression using interval arithmetic.
source§fn propagate_constraints(
&self,
_interval: &Interval,
_children: &[&Interval]
) -> Result<Vec<Option<Interval>>>
fn propagate_constraints( &self, _interval: &Interval, _children: &[&Interval] ) -> Result<Vec<Option<Interval>>>
Updates/shrinks bounds for the expression using interval arithmetic.
If constraint propagation reveals an infeasibility, returns None for
the child causing infeasibility. If none of the children intervals
change, may return an empty vector instead of cloning
children
.source§fn get_ordering(&self, _children: &[SortProperties]) -> SortProperties
fn get_ordering(&self, _children: &[SortProperties]) -> SortProperties
The order information of a PhysicalExpr can be estimated from its children.
This is especially helpful for projection expressions. If we can ensure that the
order of a PhysicalExpr to project matches with the order of SortExec, we can
eliminate that SortExecs. Read more
Auto Trait Implementations§
impl !RefUnwindSafe for GetIndexedFieldExpr
impl Send for GetIndexedFieldExpr
impl Sync for GetIndexedFieldExpr
impl Unpin for GetIndexedFieldExpr
impl !UnwindSafe for GetIndexedFieldExpr
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