pub struct DateTimeIntervalExpr { /* private fields */ }
Expand description
Perform DATE/TIME/TIMESTAMP +/ INTERVAL math
Implementations§
source§impl DateTimeIntervalExpr
impl DateTimeIntervalExpr
sourcepub fn new(
lhs: Arc<dyn PhysicalExpr>,
op: Operator,
rhs: Arc<dyn PhysicalExpr>
) -> Self
pub fn new( lhs: Arc<dyn PhysicalExpr>, op: Operator, rhs: Arc<dyn PhysicalExpr> ) -> Self
Create a new instance of DateIntervalExpr
sourcepub fn lhs(&self) -> &Arc<dyn PhysicalExpr>
pub fn lhs(&self) -> &Arc<dyn PhysicalExpr>
Get the left-hand side expression
sourcepub fn rhs(&self) -> &Arc<dyn PhysicalExpr>
pub fn rhs(&self) -> &Arc<dyn PhysicalExpr>
Get the right-hand side expression
Trait Implementations§
source§impl Debug for DateTimeIntervalExpr
impl Debug for DateTimeIntervalExpr
source§impl Display for DateTimeIntervalExpr
impl Display for DateTimeIntervalExpr
source§impl Hash for DateTimeIntervalExpr
impl Hash for DateTimeIntervalExpr
source§impl PartialEq<dyn Any> for DateTimeIntervalExpr
impl PartialEq<dyn Any> for DateTimeIntervalExpr
source§impl PhysicalExpr for DateTimeIntervalExpr
impl PhysicalExpr for DateTimeIntervalExpr
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 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 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 analyze(&self, context: AnalysisContext) -> AnalysisContext
fn analyze(&self, context: AnalysisContext) -> AnalysisContext
Return the boundaries of this expression. This method (and all the
related APIs) are experimental and subject to change.
Auto Trait Implementations§
impl !RefUnwindSafe for DateTimeIntervalExpr
impl Send for DateTimeIntervalExpr
impl Sync for DateTimeIntervalExpr
impl Unpin for DateTimeIntervalExpr
impl !UnwindSafe for DateTimeIntervalExpr
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