Struct mz_persist_types::stats::StructStats

source ·
pub struct StructStats {
    pub len: usize,
    pub cols: BTreeMap<String, Box<dyn DynStats>>,
}
Expand description

Statistics about a column of a struct type with a uniform schema (the same columns and associated T: Data types in each instance of the struct).

Fields§

§len: usize

The count of structs in the column.

§cols: BTreeMap<String, Box<dyn DynStats>>

Statistics about each of the columns in the struct.

This will often be all of the columns, but it’s not guaranteed. Persist reserves the right to prune statistics about some or all of the columns.

Implementations§

source§

impl StructStats

source

pub fn col<T: Data>(&self, name: &str) -> Result<Option<&T::Stats>, String>

Returns the statistics for the given column in the struct.

This will often be all of the columns, but it’s not guaranteed. Persist reserves the right to prune statistics about some or all of the columns.

Trait Implementations§

source§

impl Arbitrary for StructStats

§

type Parameters = <usize as Arbitrary>::Parameters

The type of parameters that arbitrary_with accepts for configuration of the generated Strategy. Parameters must implement Default.
§

type Strategy = Map<(<usize as Arbitrary>::Strategy, BoxedStrategy<BTreeMap<String, Box<dyn DynStats>>>), fn(_: (usize, BTreeMap<String, Box<dyn DynStats>>)) -> StructStats>

The type of Strategy used to generate values of type Self.
source§

fn arbitrary_with(_top: Self::Parameters) -> Self::Strategy

Generates a Strategy for producing arbitrary values of type the implementing type (Self). The strategy is passed the arguments given in args. Read more
source§

fn arbitrary() -> Self::Strategy

Generates a Strategy for producing arbitrary values of type the implementing type (Self). Read more
source§

impl ColumnStats<DynStruct> for StructStats

source§

fn lower<'a>(&'a self) -> Option<<DynStruct as Data>::Ref<'a>>

An inclusive lower bound on the data contained in the column, if known. Read more
source§

fn upper<'a>(&'a self) -> Option<<DynStruct as Data>::Ref<'a>>

Same as Self::lower but an (also inclusive) upper bound.
source§

fn none_count(&self) -> usize

The number of Nones if this column is optional or 0 if it isn’t.
source§

impl Debug for StructStats

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for StructStats

source§

fn default() -> StructStats

Returns the “default value” for a type. Read more
source§

impl DynStats for StructStats

source§

fn as_any(&self) -> &dyn Any

Returns self as a dyn Any for downcasting.
source§

fn into_proto(&self) -> ProtoDynStats

source§

fn debug_json(&self) -> Value

Formats these statistics for use in INSPECT SHARD and debugging.
source§

fn type_name(&self) -> &'static str

Returns the name of the erased type for use in error messages.
source§

impl RustType<ProtoStructStats> for StructStats

source§

fn into_proto(&self) -> ProtoStructStats

Convert a Self into a Proto value.
source§

fn from_proto(proto: ProtoStructStats) -> Result<Self, TryFromProtoError>

Consume and convert a Proto back into a Self value. Read more
source§

impl Serialize for StructStats

source§

fn serialize<S: Serializer>(&self, s: S) -> Result<S::Ok, S::Error>

Serialize this value into the given Serde serializer. Read more
source§

impl StatsFrom<DynStructCol> for StructStats

source§

fn stats_from(col: &DynStructCol, validity: ValidityRef) -> Self

Computes statistics from a column of data. Read more

Auto Trait Implementations§

Blanket Implementations§

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, U> CastInto<U> for T
where U: CastFrom<T>,

source§

fn cast_into(self) -> U

Performs the cast.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> FutureExt for T

source§

fn with_context(self, otel_cx: Context) -> WithContext<Self>

Attaches the provided Context to this type, returning a WithContext wrapper. Read more
source§

fn with_current_context(self) -> WithContext<Self>

Attaches the current Context to this type, returning a WithContext wrapper. Read more
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> IntoRequest<T> for T

source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
source§

impl<T> Pointable for T

source§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<P, R> ProtoType<R> for P
where R: RustType<P>,

source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

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

§

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>,

§

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<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