#[non_exhaustive]pub enum OwnedColumn<S: Scalar> {
Boolean(Vec<bool>),
TinyInt(Vec<i8>),
SmallInt(Vec<i16>),
Int(Vec<i32>),
BigInt(Vec<i64>),
VarChar(Vec<String>),
Int128(Vec<i128>),
Decimal75(Precision, i8, Vec<S>),
Scalar(Vec<S>),
TimestampTZ(PoSQLTimeUnit, PoSQLTimeZone, Vec<i64>),
}
Expand description
Supported types for OwnedColumn
Variants (Non-exhaustive)§
This enum is marked as non-exhaustive
Boolean(Vec<bool>)
Boolean columns
TinyInt(Vec<i8>)
i8 columns
SmallInt(Vec<i16>)
i16 columns
Int(Vec<i32>)
i32 columns
BigInt(Vec<i64>)
i64 columns
VarChar(Vec<String>)
String columns
Int128(Vec<i128>)
i128 columns
Decimal75(Precision, i8, Vec<S>)
Decimal columns
Scalar(Vec<S>)
Scalar columns
TimestampTZ(PoSQLTimeUnit, PoSQLTimeZone, Vec<i64>)
Timestamp columns
Implementations§
Source§impl<S: Scalar> OwnedColumn<S>
impl<S: Scalar> OwnedColumn<S>
Sourcepub fn try_permute(
&self,
permutation: &Permutation,
) -> Result<Self, PermutationError>
pub fn try_permute( &self, permutation: &Permutation, ) -> Result<Self, PermutationError>
Returns the column with its entries permutated
Sourcepub fn column_type(&self) -> ColumnType
pub fn column_type(&self) -> ColumnType
Returns the type of the column.
Sourcepub fn try_from_scalars(
scalars: &[S],
column_type: ColumnType,
) -> OwnedColumnResult<Self>
pub fn try_from_scalars( scalars: &[S], column_type: ColumnType, ) -> OwnedColumnResult<Self>
Convert a slice of scalars to a vec of owned columns
Sourcepub fn try_from_option_scalars(
option_scalars: &[Option<S>],
column_type: ColumnType,
) -> OwnedColumnResult<Self>
pub fn try_from_option_scalars( option_scalars: &[Option<S>], column_type: ColumnType, ) -> OwnedColumnResult<Self>
Convert a slice of option scalars to a vec of owned columns
Source§impl<S: Scalar> OwnedColumn<S>
impl<S: Scalar> OwnedColumn<S>
Sourcepub fn element_wise_not(&self) -> ColumnOperationResult<Self>
pub fn element_wise_not(&self) -> ColumnOperationResult<Self>
Element-wise NOT operation for a column
Sourcepub fn element_wise_and(&self, rhs: &Self) -> ColumnOperationResult<Self>
pub fn element_wise_and(&self, rhs: &Self) -> ColumnOperationResult<Self>
Element-wise AND for two columns
Sourcepub fn element_wise_or(&self, rhs: &Self) -> ColumnOperationResult<Self>
pub fn element_wise_or(&self, rhs: &Self) -> ColumnOperationResult<Self>
Element-wise OR for two columns
Sourcepub fn element_wise_eq(&self, rhs: &Self) -> ColumnOperationResult<Self>
pub fn element_wise_eq(&self, rhs: &Self) -> ColumnOperationResult<Self>
Element-wise equality check for two columns
Sourcepub fn element_wise_le(&self, rhs: &Self) -> ColumnOperationResult<Self>
pub fn element_wise_le(&self, rhs: &Self) -> ColumnOperationResult<Self>
Element-wise less than or equal to check for two columns
Sourcepub fn element_wise_ge(&self, rhs: &Self) -> ColumnOperationResult<Self>
pub fn element_wise_ge(&self, rhs: &Self) -> ColumnOperationResult<Self>
Element-wise greater than or equal to check for two columns
Sourcepub fn element_wise_add(
&self,
rhs: &OwnedColumn<S>,
) -> ColumnOperationResult<OwnedColumn<S>>
pub fn element_wise_add( &self, rhs: &OwnedColumn<S>, ) -> ColumnOperationResult<OwnedColumn<S>>
Element-wise addition for two columns
Sourcepub fn element_wise_sub(
&self,
rhs: &OwnedColumn<S>,
) -> ColumnOperationResult<OwnedColumn<S>>
pub fn element_wise_sub( &self, rhs: &OwnedColumn<S>, ) -> ColumnOperationResult<OwnedColumn<S>>
Element-wise subtraction for two columns
Sourcepub fn element_wise_mul(
&self,
rhs: &OwnedColumn<S>,
) -> ColumnOperationResult<OwnedColumn<S>>
pub fn element_wise_mul( &self, rhs: &OwnedColumn<S>, ) -> ColumnOperationResult<OwnedColumn<S>>
Element-wise multiplication for two columns
Sourcepub fn element_wise_div(
&self,
rhs: &OwnedColumn<S>,
) -> ColumnOperationResult<OwnedColumn<S>>
pub fn element_wise_div( &self, rhs: &OwnedColumn<S>, ) -> ColumnOperationResult<OwnedColumn<S>>
Element-wise division for two columns
Trait Implementations§
Source§impl<S: Clone + Scalar> Clone for OwnedColumn<S>
impl<S: Clone + Scalar> Clone for OwnedColumn<S>
Source§fn clone(&self) -> OwnedColumn<S>
fn clone(&self) -> OwnedColumn<S>
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moreSource§impl<'de, S> Deserialize<'de> for OwnedColumn<S>where
S: Deserialize<'de> + Scalar,
impl<'de, S> Deserialize<'de> for OwnedColumn<S>where
S: Deserialize<'de> + Scalar,
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Source§impl<'a, S: Scalar> From<&'a OwnedColumn<S>> for CommittableColumn<'a>
impl<'a, S: Scalar> From<&'a OwnedColumn<S>> for CommittableColumn<'a>
Source§fn from(value: &'a OwnedColumn<S>) -> Self
fn from(value: &'a OwnedColumn<S>) -> Self
Source§impl<S: Scalar> From<OwnedColumn<S>> for ArrayRef
§Panics
Will panic if setting precision and scale fails when converting OwnedColumn::Int128
.
Will panic if setting precision and scale fails when converting OwnedColumn::Decimal75
.
Will panic if trying to convert OwnedColumn::Scalar
, as this conversion is not implemented
impl<S: Scalar> From<OwnedColumn<S>> for ArrayRef
§Panics
Will panic if setting precision and scale fails when converting OwnedColumn::Int128
.
Will panic if setting precision and scale fails when converting OwnedColumn::Decimal75
.
Will panic if trying to convert OwnedColumn::Scalar
, as this conversion is not implemented
Source§fn from(value: OwnedColumn<S>) -> Self
fn from(value: OwnedColumn<S>) -> Self
Source§impl<S> Serialize for OwnedColumn<S>
impl<S> Serialize for OwnedColumn<S>
Source§impl<S: Scalar> TryFrom<&Arc<dyn Array>> for OwnedColumn<S>
impl<S: Scalar> TryFrom<&Arc<dyn Array>> for OwnedColumn<S>
Source§fn try_from(value: &ArrayRef) -> Result<Self, Self::Error>
fn try_from(value: &ArrayRef) -> Result<Self, Self::Error>
§Panics
Will panic if downcasting fails for the following types:
BooleanArray
when converting fromDataType::Boolean
.Int16Array
when converting fromDataType::Int16
.Int32Array
when converting fromDataType::Int32
.Int64Array
when converting fromDataType::Int64
.Decimal128Array
when converting fromDataType::Decimal128(38, 0)
.Decimal256Array
when converting fromDataType::Decimal256
if precision is less than or equal to 75.StringArray
when converting fromDataType::Utf8
.
Source§type Error = OwnedArrowConversionError
type Error = OwnedArrowConversionError
impl<S: Eq + Scalar> Eq for OwnedColumn<S>
impl<S: Scalar> StructuralPartialEq for OwnedColumn<S>
Auto Trait Implementations§
impl<S> Freeze for OwnedColumn<S>
impl<S> RefUnwindSafe for OwnedColumn<S>where
S: RefUnwindSafe,
impl<S> Send for OwnedColumn<S>
impl<S> Sync for OwnedColumn<S>
impl<S> Unpin for OwnedColumn<S>where
S: Unpin,
impl<S> UnwindSafe for OwnedColumn<S>where
S: UnwindSafe,
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
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§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
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
key
and return true
if they are equal.Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
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>
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>
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