pub enum Value {
Show 24 variants
Null,
Boolean(bool),
UInt8(u8),
UInt16(u16),
UInt32(u32),
UInt64(u64),
Int8(i8),
Int16(i16),
Int32(i32),
Int64(i64),
Float32(OrderedF32),
Float64(OrderedF64),
Decimal128(Decimal128),
String(StringBytes),
Binary(Bytes),
Date(Date),
DateTime(DateTime),
Timestamp(Timestamp),
Time(Time),
Duration(Duration),
IntervalYearMonth(IntervalYearMonth),
IntervalDayTime(IntervalDayTime),
IntervalMonthDayNano(IntervalMonthDayNano),
List(ListValue),
}
Expand description
Value holds a single arbitrary value of any DataType.
Comparison between values with different types (expect Null) is not allowed.
Variants§
Null
Boolean(bool)
UInt8(u8)
UInt16(u16)
UInt32(u32)
UInt64(u64)
Int8(i8)
Int16(i16)
Int32(i32)
Int64(i64)
Float32(OrderedF32)
Float64(OrderedF64)
Decimal128(Decimal128)
String(StringBytes)
Binary(Bytes)
Date(Date)
DateTime(DateTime)
Timestamp(Timestamp)
Time(Time)
Duration(Duration)
IntervalYearMonth(IntervalYearMonth)
IntervalDayTime(IntervalDayTime)
IntervalMonthDayNano(IntervalMonthDayNano)
List(ListValue)
Implementations§
Source§impl Value
impl Value
Sourcepub fn data_type(&self) -> ConcreteDataType
pub fn data_type(&self) -> ConcreteDataType
Sourcepub fn as_value_ref(&self) -> ValueRef<'_>
pub fn as_value_ref(&self) -> ValueRef<'_>
Cast itself to ValueRef.
Sourcepub fn as_timestamp(&self) -> Option<Timestamp>
pub fn as_timestamp(&self) -> Option<Timestamp>
Cast Value to timestamp. Return None if value is not a valid timestamp data type.
Sourcepub fn as_string(&self) -> Option<String>
pub fn as_string(&self) -> Option<String>
Cast Value to utf8 String. Return None if value is not a valid string data type.
Sourcepub fn as_date(&self) -> Option<Date>
pub fn as_date(&self) -> Option<Date>
Cast Value to Date. Return None if value is not a valid date data type.
Sourcepub fn as_datetime(&self) -> Option<DateTime>
pub fn as_datetime(&self) -> Option<DateTime>
Cast Value to DateTime. Return None if value is not a valid datetime data type.
Sourcepub fn as_time(&self) -> Option<Time>
pub fn as_time(&self) -> Option<Time>
Cast Value to [Time]. Return None if value is not a valid time data type.
Sourcepub fn as_interval_year_month(&self) -> Option<IntervalYearMonth>
pub fn as_interval_year_month(&self) -> Option<IntervalYearMonth>
Cast Value to [IntervalYearMonth]. Return None if value is not a valid interval year month data type.
Sourcepub fn as_interval_day_time(&self) -> Option<IntervalDayTime>
pub fn as_interval_day_time(&self) -> Option<IntervalDayTime>
Cast Value to [IntervalDayTime]. Return None if value is not a valid interval day time data type.
Sourcepub fn as_interval_month_day_nano(&self) -> Option<IntervalMonthDayNano>
pub fn as_interval_month_day_nano(&self) -> Option<IntervalMonthDayNano>
Cast Value to [IntervalMonthDayNano]. Return None if value is not a valid interval month day nano data type.
Sourcepub fn as_u64(&self) -> Option<u64>
pub fn as_u64(&self) -> Option<u64>
Cast Value to u64. Return None if value is not a valid uint64 data type.
Sourcepub fn as_f64_lossy(&self) -> Option<f64>
pub fn as_f64_lossy(&self) -> Option<f64>
Cast Value to f64. Return None if it’s not castable;
Sourcepub fn logical_type_id(&self) -> LogicalTypeId
pub fn logical_type_id(&self) -> LogicalTypeId
Returns the logical type of the value.
Sourcepub fn try_to_scalar_value(
&self,
output_type: &ConcreteDataType,
) -> Result<ScalarValue>
pub fn try_to_scalar_value( &self, output_type: &ConcreteDataType, ) -> Result<ScalarValue>
Convert the value into [ScalarValue
] according to the output_type
.
Sourcepub fn try_negative(&self) -> Option<Self>
pub fn try_negative(&self) -> Option<Self>
Apply -
unary op if possible
Trait Implementations§
Source§impl<'de> Deserialize<'de> for Value
impl<'de> Deserialize<'de> for Value
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 From<DurationMicrosecond> for Value
impl From<DurationMicrosecond> for Value
Source§fn from(t: DurationMicrosecond) -> Value
fn from(t: DurationMicrosecond) -> Value
Source§impl From<DurationMillisecond> for Value
impl From<DurationMillisecond> for Value
Source§fn from(t: DurationMillisecond) -> Value
fn from(t: DurationMillisecond) -> Value
Source§impl From<DurationNanosecond> for Value
impl From<DurationNanosecond> for Value
Source§fn from(t: DurationNanosecond) -> Value
fn from(t: DurationNanosecond) -> Value
Source§impl From<DurationSecond> for Value
impl From<DurationSecond> for Value
Source§fn from(t: DurationSecond) -> Value
fn from(t: DurationSecond) -> Value
Source§impl From<Option<OrderedFloat<f32>>> for Value
impl From<Option<OrderedFloat<f32>>> for Value
Source§fn from(value: Option<OrderedF32>) -> Self
fn from(value: Option<OrderedF32>) -> Self
Source§impl From<Option<OrderedFloat<f64>>> for Value
impl From<Option<OrderedFloat<f64>>> for Value
Source§fn from(value: Option<OrderedF64>) -> Self
fn from(value: Option<OrderedF64>) -> Self
Source§impl<T: WrapperType> From<OrdPrimitive<T>> for Value
impl<T: WrapperType> From<OrdPrimitive<T>> for Value
Source§fn from(p: OrdPrimitive<T>) -> Self
fn from(p: OrdPrimitive<T>) -> Self
Source§impl From<OrderedFloat<f32>> for Value
impl From<OrderedFloat<f32>> for Value
Source§fn from(value: OrderedF32) -> Self
fn from(value: OrderedF32) -> Self
Source§impl From<OrderedFloat<f64>> for Value
impl From<OrderedFloat<f64>> for Value
Source§fn from(value: OrderedF64) -> Self
fn from(value: OrderedF64) -> Self
Source§impl From<TimeMicrosecond> for Value
impl From<TimeMicrosecond> for Value
Source§fn from(t: TimeMicrosecond) -> Value
fn from(t: TimeMicrosecond) -> Value
Source§impl From<TimeMillisecond> for Value
impl From<TimeMillisecond> for Value
Source§fn from(t: TimeMillisecond) -> Value
fn from(t: TimeMillisecond) -> Value
Source§impl From<TimeNanosecond> for Value
impl From<TimeNanosecond> for Value
Source§fn from(t: TimeNanosecond) -> Value
fn from(t: TimeNanosecond) -> Value
Source§impl From<TimeSecond> for Value
impl From<TimeSecond> for Value
Source§fn from(t: TimeSecond) -> Value
fn from(t: TimeSecond) -> Value
Source§impl From<TimestampMicrosecond> for Value
impl From<TimestampMicrosecond> for Value
Source§fn from(t: TimestampMicrosecond) -> Value
fn from(t: TimestampMicrosecond) -> Value
Source§impl From<TimestampMillisecond> for Value
impl From<TimestampMillisecond> for Value
Source§fn from(t: TimestampMillisecond) -> Value
fn from(t: TimestampMillisecond) -> Value
Source§impl From<TimestampNanosecond> for Value
impl From<TimestampNanosecond> for Value
Source§fn from(t: TimestampNanosecond) -> Value
fn from(t: TimestampNanosecond) -> Value
Source§impl From<TimestampSecond> for Value
impl From<TimestampSecond> for Value
Source§fn from(t: TimestampSecond) -> Value
fn from(t: TimestampSecond) -> Value
Source§impl Ord for Value
impl Ord for Value
Source§impl PartialOrd for Value
impl PartialOrd for Value
Source§impl TryAsPrimitive<Float32Type> for Value
impl TryAsPrimitive<Float32Type> for Value
fn try_as_primitive( &self, ) -> Option<<Float32Type as LogicalPrimitiveType>::Native>
Source§impl TryAsPrimitive<Float64Type> for Value
impl TryAsPrimitive<Float64Type> for Value
fn try_as_primitive( &self, ) -> Option<<Float64Type as LogicalPrimitiveType>::Native>
Source§impl TryAsPrimitive<Int16Type> for Value
impl TryAsPrimitive<Int16Type> for Value
fn try_as_primitive( &self, ) -> Option<<Int16Type as LogicalPrimitiveType>::Native>
Source§impl TryAsPrimitive<Int32Type> for Value
impl TryAsPrimitive<Int32Type> for Value
fn try_as_primitive( &self, ) -> Option<<Int32Type as LogicalPrimitiveType>::Native>
Source§impl TryAsPrimitive<Int64Type> for Value
impl TryAsPrimitive<Int64Type> for Value
fn try_as_primitive( &self, ) -> Option<<Int64Type as LogicalPrimitiveType>::Native>
Source§impl TryAsPrimitive<Int8Type> for Value
impl TryAsPrimitive<Int8Type> for Value
fn try_as_primitive(&self) -> Option<<Int8Type as LogicalPrimitiveType>::Native>
Source§impl TryAsPrimitive<UInt16Type> for Value
impl TryAsPrimitive<UInt16Type> for Value
fn try_as_primitive( &self, ) -> Option<<UInt16Type as LogicalPrimitiveType>::Native>
Source§impl TryAsPrimitive<UInt32Type> for Value
impl TryAsPrimitive<UInt32Type> for Value
fn try_as_primitive( &self, ) -> Option<<UInt32Type as LogicalPrimitiveType>::Native>
Source§impl TryAsPrimitive<UInt64Type> for Value
impl TryAsPrimitive<UInt64Type> for Value
fn try_as_primitive( &self, ) -> Option<<UInt64Type as LogicalPrimitiveType>::Native>
Source§impl TryAsPrimitive<UInt8Type> for Value
impl TryAsPrimitive<UInt8Type> for Value
fn try_as_primitive( &self, ) -> Option<<UInt8Type as LogicalPrimitiveType>::Native>
Source§impl TryFrom<Value> for OrderedF32
impl TryFrom<Value> for OrderedF32
Source§impl TryFrom<Value> for OrderedF64
impl TryFrom<Value> for OrderedF64
impl Eq for Value
impl StructuralPartialEq for Value
Auto Trait Implementations§
impl !Freeze for Value
impl RefUnwindSafe for Value
impl Send for Value
impl Sync for Value
impl Unpin for Value
impl UnwindSafe for Value
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
§impl<T> CallHasher for T
impl<T> CallHasher for T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<Q, K> Comparable<K> for Q
impl<Q, K> Comparable<K> for Q
§impl<T> Conv for T
impl<T> Conv for T
§impl<T, V> Convert<T> for Vwhere
V: Into<T>,
impl<T, V> Convert<T> for Vwhere
V: Into<T>,
fn convert(value: Self) -> T
fn convert_box(value: Box<Self>) -> Box<T>
fn convert_vec(value: Vec<Self>) -> Vec<T>
fn convert_vec_box(value: Vec<Box<Self>>) -> Vec<Box<T>>
fn convert_matrix(value: Vec<Vec<Self>>) -> Vec<Vec<T>>
fn convert_option(value: Option<Self>) -> Option<T>
fn convert_option_box(value: Option<Box<Self>>) -> Option<Box<T>>
fn convert_option_vec(value: Option<Vec<Self>>) -> Option<Vec<T>>
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.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.§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
§impl<T> FmtForward for T
impl<T> FmtForward for T
§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self
to use its Binary
implementation when Debug
-formatted.§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self
to use its Display
implementation when
Debug
-formatted.§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self
to use its LowerExp
implementation when
Debug
-formatted.§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self
to use its LowerHex
implementation when
Debug
-formatted.§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self
to use its Octal
implementation when Debug
-formatted.§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self
to use its Pointer
implementation when
Debug
-formatted.§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self
to use its UpperExp
implementation when
Debug
-formatted.§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self
to use its UpperHex
implementation when
Debug
-formatted.§fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
§impl<T> FutureExt for T
impl<T> FutureExt for T
§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§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 moreSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T
in a tonic::Request
Source§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T
in a tonic::Request
§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read more§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read more§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self
, then passes self.as_ref()
into the pipe function.§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self
, then passes self.as_mut()
into the pipe
function.§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self
, then passes self.deref()
into the pipe function.§impl<T> Tap for T
impl<T> Tap for T
§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B>
of a value. Read more§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B>
of a value. Read more§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R>
view of a value. Read more§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R>
view of a value. Read more§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target
of a value. Read more§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target
of a value. Read more§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap()
only in debug builds, and is erased in release builds.§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut()
only in debug builds, and is erased in release
builds.§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow()
only in debug builds, and is erased in release
builds.§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut()
only in debug builds, and is erased in release
builds.§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref()
only in debug builds, and is erased in release
builds.§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut()
only in debug builds, and is erased in release
builds.§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref()
only in debug builds, and is erased in release
builds.