Skip to main content

PartitionPruningStatistics

Struct PartitionPruningStatistics 

Source
pub struct PartitionPruningStatistics { /* private fields */ }
๐Ÿ‘ŽDeprecated since 52.0.0: This struct is no longer used internally. Use replace_columns_with_literals from datafusion-physical-expr-adapter to substitute partition column values before pruning. It will be removed in 58.0.0 or 6 months after 52.0.0 is released, whichever comes first.
Expand description

Prune files based on their partition values.

This is used both at planning time and execution time to prune files based on their partition values. This feeds into CompositePruningStatistics to allow pruning with filters that depend both on partition columns and data columns (e.g. WHERE partition_col = data_col).

Implementationsยง

Sourceยง

impl PartitionPruningStatistics

Source

pub fn try_new( partition_values: Vec<Vec<ScalarValue>>, partition_fields: Vec<Arc<Field>>, ) -> Result<PartitionPruningStatistics, DataFusionError>

Create a new instance of PartitionPruningStatistics.

Args:

  • partition_values: A vector of vectors of ScalarValues. The outer vector represents the containers while the inner vector represents the partition values for each column. Note that this is the opposite of the order of the partition columns in PartitionPruningStatistics::partition_schema.
  • partition_schema: The schema of the partition columns. This must not be the schema of the entire file or table: instead it must only be the schema of the partition columns, in the same order as the values in partition_values.
ยงExample

To create PartitionPruningStatistics for two partition columns a and b, for three containers like this:

ab
12
34
56

let partition_values = vec![
    vec![ScalarValue::from(1i32), ScalarValue::from(2i32)],
    vec![ScalarValue::from(3i32), ScalarValue::from(4i32)],
    vec![ScalarValue::from(5i32), ScalarValue::from(6i32)],
];
let partition_fields = vec![
    Arc::new(Field::new("a", DataType::Int32, false)),
    Arc::new(Field::new("b", DataType::Int32, false)),
];
let partition_stats =
    PartitionPruningStatistics::try_new(partition_values, partition_fields).unwrap();

Trait Implementationsยง

Sourceยง

impl Clone for PartitionPruningStatistics

Sourceยง

fn clone(&self) -> PartitionPruningStatistics

Returns a duplicate of the value. Read more
1.0.0 ยท Sourceยง

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Sourceยง

impl PruningStatistics for PartitionPruningStatistics

Sourceยง

fn min_values(&self, column: &Column) -> Option<Arc<dyn Array>>

Return the minimum values for the named column, if known. Read more
Sourceยง

fn max_values(&self, column: &Column) -> Option<Arc<dyn Array>>

Return the maximum values for the named column, if known. Read more
Sourceยง

fn num_containers(&self) -> usize

Return the number of containers (e.g. Row Groups) being pruned with these statistics. Read more
Sourceยง

fn null_counts(&self, _column: &Column) -> Option<Arc<dyn Array>>

Return the number of null values for the named column as an UInt64Array Read more
Sourceยง

fn row_counts(&self, _column: &Column) -> Option<Arc<dyn Array>>

Return the number of rows for the named column in each container as an UInt64Array. Read more
Sourceยง

fn contained( &self, column: &Column, values: &HashSet<ScalarValue>, ) -> Option<BooleanArray>

Returns BooleanArray where each row represents information known about specific literal values in a column. Read more

Auto Trait Implementationsยง

Blanket Implementationsยง

Sourceยง

impl<T> AlignerFor<1> for T

Sourceยง

type Aligner = AlignTo1<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Sourceยง

impl<T> AlignerFor<1024> for T

Sourceยง

type Aligner = AlignTo1024<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Sourceยง

impl<T> AlignerFor<128> for T

Sourceยง

type Aligner = AlignTo128<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Sourceยง

impl<T> AlignerFor<16> for T

Sourceยง

type Aligner = AlignTo16<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Sourceยง

impl<T> AlignerFor<16384> for T

Sourceยง

type Aligner = AlignTo16384<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Sourceยง

impl<T> AlignerFor<2> for T

Sourceยง

type Aligner = AlignTo2<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Sourceยง

impl<T> AlignerFor<2048> for T

Sourceยง

type Aligner = AlignTo2048<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Sourceยง

impl<T> AlignerFor<256> for T

Sourceยง

type Aligner = AlignTo256<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Sourceยง

impl<T> AlignerFor<32> for T

Sourceยง

type Aligner = AlignTo32<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Sourceยง

impl<T> AlignerFor<32768> for T

Sourceยง

type Aligner = AlignTo32768<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Sourceยง

impl<T> AlignerFor<4> for T

Sourceยง

type Aligner = AlignTo4<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Sourceยง

impl<T> AlignerFor<4096> for T

Sourceยง

type Aligner = AlignTo4096<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Sourceยง

impl<T> AlignerFor<512> for T

Sourceยง

type Aligner = AlignTo512<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Sourceยง

impl<T> AlignerFor<64> for T

Sourceยง

type Aligner = AlignTo64<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Sourceยง

impl<T> AlignerFor<8> for T

Sourceยง

type Aligner = AlignTo8<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Sourceยง

impl<T> AlignerFor<8192> for T

Sourceยง

type Aligner = AlignTo8192<T>

The AlignTo* type which aligns Self to ALIGNMENT.
Sourceยง

impl<T> Any for T
where T: 'static + ?Sized,

Sourceยง

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Sourceยง

impl<T> Borrow<T> for T
where T: ?Sized,

Sourceยง

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Sourceยง

impl<T> BorrowMut<T> for T
where T: ?Sized,

Sourceยง

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Sourceยง

impl<T> CloneToUninit for T
where T: Clone,

Sourceยง

unsafe fn clone_to_uninit(&self, dest: *mut u8)

๐Ÿ”ฌThis is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Sourceยง

impl<T> From<T> for T

Sourceยง

fn from(t: T) -> T

Returns the argument unchanged.

Sourceยง

impl<T, W> HasTypeWitness<W> for T
where W: MakeTypeWitness<Arg = T>, T: ?Sized,

Sourceยง

const WITNESS: W = W::MAKE

A constant of the type witness
Sourceยง

impl<T> Identity for T
where T: ?Sized,

Sourceยง

const TYPE_EQ: TypeEq<T, <T as Identity>::Type> = TypeEq::NEW

Proof that Self is the same type as Self::Type, provides methods for casting between Self and Self::Type.
Sourceยง

type Type = T

The same type as Self, used to emulate type equality bounds (T == U) with associated type equality constraints (T: Identity<Type = U>).
Sourceยง

impl<T> Instrument for T

Sourceยง

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Sourceยง

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Sourceยง

impl<T, U> Into<U> for T
where U: From<T>,

Sourceยง

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Sourceยง

impl<T> IntoEither for T

Sourceยง

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 more
Sourceยง

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
Sourceยง

impl<T> PolicyExt for T
where T: ?Sized,

Sourceยง

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Sourceยง

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Sourceยง

impl<'a, T> RCowCompatibleRef<'a> for T
where T: Clone + 'a,

Sourceยง

type RefC = &'a T

The (preferably) ffi-safe equivalent of &Self.
Sourceยง

type ROwned = T

The owned version of Self::RefC.
Sourceยง

fn as_c_ref(from: &'a T) -> <T as RCowCompatibleRef<'a>>::RefC

Converts a reference to an FFI-safe type
Sourceยง

fn as_rust_ref(from: <T as RCowCompatibleRef<'a>>::RefC) -> &'a T

Converts an FFI-safe type to a reference
Sourceยง

impl<S> ROExtAcc for S

Sourceยง

fn f_get<F>(&self, offset: FieldOffset<S, F, Aligned>) -> &F

Gets a reference to a field, determined by offset. Read more
Sourceยง

fn f_get_mut<F>(&mut self, offset: FieldOffset<S, F, Aligned>) -> &mut F

Gets a muatble reference to a field, determined by offset. Read more
Sourceยง

fn f_get_ptr<F, A>(&self, offset: FieldOffset<S, F, A>) -> *const F

Gets a const pointer to a field, the field is determined by offset. Read more
Sourceยง

fn f_get_mut_ptr<F, A>(&mut self, offset: FieldOffset<S, F, A>) -> *mut F

Gets a mutable pointer to a field, determined by offset. Read more
Sourceยง

impl<S> ROExtOps<Aligned> for S

Sourceยง

fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Aligned>, value: F) -> F

Replaces a field (determined by offset) with value, returning the previous value of the field. Read more
Sourceยง

fn f_swap<F>(&mut self, offset: FieldOffset<S, F, Aligned>, right: &mut S)

Swaps a field (determined by offset) with the same field in right. Read more
Sourceยง

fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Aligned>) -> F
where F: Copy,

Gets a copy of a field (determined by offset). The field is determined by offset. Read more
Sourceยง

impl<S> ROExtOps<Unaligned> for S

Sourceยง

fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Unaligned>, value: F) -> F

Replaces a field (determined by offset) with value, returning the previous value of the field. Read more
Sourceยง

fn f_swap<F>(&mut self, offset: FieldOffset<S, F, Unaligned>, right: &mut S)

Swaps a field (determined by offset) with the same field in right. Read more
Sourceยง

fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Unaligned>) -> F
where F: Copy,

Gets a copy of a field (determined by offset). The field is determined by offset. Read more
Sourceยง

impl<T> Same for T

Sourceยง

type Output = T

Should always be Self
Sourceยง

impl<T> SelfOps for T
where T: ?Sized,

Sourceยง

fn eq_id(&self, other: &Self) -> bool

Compares the address of self with the address of other. Read more
Sourceยง

fn piped<F, U>(self, f: F) -> U
where F: FnOnce(Self) -> U, Self: Sized,

Emulates the pipeline operator, allowing method syntax in more places. Read more
Sourceยง

fn piped_ref<'a, F, U>(&'a self, f: F) -> U
where F: FnOnce(&'a Self) -> U,

The same as piped except that the function takes &Self Useful for functions that take &Self instead of Self. Read more
Sourceยง

fn piped_mut<'a, F, U>(&'a mut self, f: F) -> U
where F: FnOnce(&'a mut Self) -> U,

The same as piped, except that the function takes &mut Self. Useful for functions that take &mut Self instead of Self.
Sourceยง

fn mutated<F>(self, f: F) -> Self
where F: FnOnce(&mut Self), Self: Sized,

Mutates self using a closure taking self by mutable reference, passing it along the method chain. Read more
Sourceยง

fn observe<F>(self, f: F) -> Self
where F: FnOnce(&Self), Self: Sized,

Observes the value of self, passing it along unmodified. Useful in long method chains. Read more
Sourceยง

fn into_<T>(self) -> T
where Self: Into<T>,

Performs a conversion with Into. using the turbofish .into_::<_>() syntax. Read more
Sourceยง

fn as_ref_<T>(&self) -> &T
where Self: AsRef<T>, T: ?Sized,

Performs a reference to reference conversion with AsRef, using the turbofish .as_ref_::<_>() syntax. Read more
Sourceยง

fn as_mut_<T>(&mut self) -> &mut T
where Self: AsMut<T>, T: ?Sized,

Performs a mutable reference to mutable reference conversion with AsMut, using the turbofish .as_mut_::<_>() syntax. Read more
Sourceยง

fn drop_(self)
where Self: Sized,

Drops self using method notation. Alternative to std::mem::drop. Read more
Sourceยง

impl<T> ToOwned for T
where T: Clone,

Sourceยง

type Owned = T

The resulting type after obtaining ownership.
Sourceยง

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Sourceยง

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Sourceยง

impl<This> TransmuteElement for This
where This: ?Sized,

Sourceยง

unsafe fn transmute_element<T>(self) -> Self::TransmutedPtr
where Self: CanTransmuteElement<T>,

Transmutes the element type of this pointer.. Read more
Sourceยง

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Sourceยง

type Error = Infallible

The type returned in the event of a conversion error.
Sourceยง

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Sourceยง

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Sourceยง

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Sourceยง

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Sourceยง

impl<T> TypeIdentity for T
where T: ?Sized,

Sourceยง

type Type = T

This is always Self.
Sourceยง

fn into_type(self) -> Self::Type
where Self: Sized, Self::Type: Sized,

Converts a value back to the original type.
Sourceยง

fn as_type(&self) -> &Self::Type

Converts a reference back to the original type.
Sourceยง

fn as_type_mut(&mut self) -> &mut Self::Type

Converts a mutable reference back to the original type.
Sourceยง

fn into_type_box(self: Box<Self>) -> Box<Self::Type>

Converts a box back to the original type.
Sourceยง

fn into_type_arc(this: Arc<Self>) -> Arc<Self::Type>

Converts an Arc back to the original type. Read more
Sourceยง

fn into_type_rc(this: Rc<Self>) -> Rc<Self::Type>

Converts an Rc back to the original type. Read more
Sourceยง

fn from_type(this: Self::Type) -> Self
where Self: Sized, Self::Type: Sized,

Converts a value back to the original type.
Sourceยง

fn from_type_ref(this: &Self::Type) -> &Self

Converts a reference back to the original type.
Sourceยง

fn from_type_mut(this: &mut Self::Type) -> &mut Self

Converts a mutable reference back to the original type.
Sourceยง

fn from_type_box(this: Box<Self::Type>) -> Box<Self>

Converts a box back to the original type.
Sourceยง

fn from_type_arc(this: Arc<Self::Type>) -> Arc<Self>

Converts an Arc back to the original type.
Sourceยง

fn from_type_rc(this: Rc<Self::Type>) -> Rc<Self>

Converts an Rc back to the original type.
Sourceยง

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Sourceยง

fn vzip(self) -> V

Sourceยง

impl<T> WithSubscriber for T

Sourceยง

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Sourceยง

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Sourceยง

impl<T> Ungil for T
where T: Send,