Enum proof_of_sql::base::database::Column
source · #[non_exhaustive]pub enum Column<'a, S: Scalar> {
Boolean(&'a [bool]),
SmallInt(&'a [i16]),
Int(&'a [i32]),
BigInt(&'a [i64]),
Int128(&'a [i128]),
Decimal75(Precision, i8, &'a [S]),
Scalar(&'a [S]),
VarChar((&'a [&'a str], &'a [S])),
TimestampTZ(PoSQLTimeUnit, PoSQLTimeZone, &'a [i64]),
}
Expand description
Represents a read-only view of a column in an in-memory, column-oriented database.
Note: The types here should correspond to native SQL database types.
See <https://ignite.apache.org/docs/latest/sql-reference/data-types>
for
a description of the native types used by Apache Ignite.
Variants (Non-exhaustive)§
This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
Boolean(&'a [bool])
Boolean columns
SmallInt(&'a [i16])
i16 columns
Int(&'a [i32])
i32 columns
BigInt(&'a [i64])
i64 columns
Int128(&'a [i128])
i128 columns
Decimal75(Precision, i8, &'a [S])
Decimal columns with a max width of 252 bits
- the backing store maps to the type crate::base::scalar::Curve25519Scalar
Scalar(&'a [S])
Scalar columns
VarChar((&'a [&'a str], &'a [S]))
String columns
- the first element maps to the str values.
- the second element maps to the str hashes (see crate::base::scalar::Scalar).
TimestampTZ(PoSQLTimeUnit, PoSQLTimeZone, &'a [i64])
Timestamp columns with timezone
- the first element maps to the stored [
TimeUnit
] - the second element maps to a timezone
- the third element maps to columns of timeunits since unix epoch
Implementations§
source§impl<'a, S: Scalar> Column<'a, S>
impl<'a, S: Scalar> Column<'a, S>
sourcepub fn column_type(&self) -> ColumnType
pub fn column_type(&self) -> ColumnType
Provides the column type associated with the column
sourcepub fn from_literal_with_length(
literal: &LiteralValue<S>,
length: usize,
alloc: &'a Bump,
) -> Self
pub fn from_literal_with_length( literal: &LiteralValue<S>, length: usize, alloc: &'a Bump, ) -> Self
Generate a constant column from a literal value with a given length
Trait Implementations§
source§impl<'a, S: PartialEq + Scalar> PartialEq for Column<'a, S>
impl<'a, S: PartialEq + Scalar> PartialEq for Column<'a, S>
impl<'a, S: Eq + Scalar> Eq for Column<'a, S>
impl<'a, S: Scalar> StructuralPartialEq for Column<'a, S>
Auto Trait Implementations§
impl<'a, S> Freeze for Column<'a, S>
impl<'a, S> RefUnwindSafe for Column<'a, S>where
S: RefUnwindSafe,
impl<'a, S> Send for Column<'a, S>
impl<'a, S> Sync for Column<'a, S>
impl<'a, S> Unpin for Column<'a, S>
impl<'a, S> UnwindSafe for Column<'a, S>where
S: RefUnwindSafe,
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
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§default unsafe fn clone_to_uninit(&self, dst: *mut T)
default unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit
)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
Compare self to
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>
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 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>
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