pub struct Batch {
primary_key: Vec<u8>,
pk_values: Option<CompositeValues>,
timestamps: VectorRef,
sequences: Arc<UInt64Vector>,
op_types: Arc<UInt8Vector>,
fields: Vec<BatchColumn>,
fields_idx: Option<HashMap<ColumnId, usize>>,
}
Expand description
Storage internal representation of a batch of rows for a primary key (time series).
Rows are sorted by primary key, timestamp, sequence desc, op_type desc. Fields always keep the same relative order as fields in RegionMetadata.
Fields§
§primary_key: Vec<u8>
Primary key encoded in a comparable form.
pk_values: Option<CompositeValues>
Possibly decoded primary_key
values. Some places would decode it in advance.
timestamps: VectorRef
Timestamps of rows, should be sorted and not null.
sequences: Arc<UInt64Vector>
Sequences of rows
UInt64 type, not null.
op_types: Arc<UInt8Vector>
Op types of rows
UInt8 type, not null.
fields: Vec<BatchColumn>
Fields organized in columnar format.
fields_idx: Option<HashMap<ColumnId, usize>>
Cache for field index lookup.
Implementations§
Source§impl Batch
impl Batch
Sourcepub fn new(
primary_key: Vec<u8>,
timestamps: VectorRef,
sequences: Arc<UInt64Vector>,
op_types: Arc<UInt8Vector>,
fields: Vec<BatchColumn>,
) -> Result<Batch>
pub fn new( primary_key: Vec<u8>, timestamps: VectorRef, sequences: Arc<UInt64Vector>, op_types: Arc<UInt8Vector>, fields: Vec<BatchColumn>, ) -> Result<Batch>
Creates a new batch.
Sourcepub fn with_fields(self, fields: Vec<BatchColumn>) -> Result<Batch>
pub fn with_fields(self, fields: Vec<BatchColumn>) -> Result<Batch>
Tries to set fields for the batch.
Sourcepub fn primary_key(&self) -> &[u8] ⓘ
pub fn primary_key(&self) -> &[u8] ⓘ
Returns primary key of the batch.
Sourcepub fn pk_values(&self) -> Option<&CompositeValues>
pub fn pk_values(&self) -> Option<&CompositeValues>
Returns possibly decoded primary-key values.
Sourcepub fn set_pk_values(&mut self, pk_values: CompositeValues)
pub fn set_pk_values(&mut self, pk_values: CompositeValues)
Sets possibly decoded primary-key values.
Sourcepub fn fields(&self) -> &[BatchColumn]
pub fn fields(&self) -> &[BatchColumn]
Returns fields in the batch.
Sourcepub fn timestamps(&self) -> &VectorRef
pub fn timestamps(&self) -> &VectorRef
Returns timestamps of the batch.
Sourcepub fn sequences(&self) -> &Arc<UInt64Vector>
pub fn sequences(&self) -> &Arc<UInt64Vector>
Returns sequences of the batch.
Sourcepub fn op_types(&self) -> &Arc<UInt8Vector>
pub fn op_types(&self) -> &Arc<UInt8Vector>
Returns op types of the batch.
Sourcepub fn first_timestamp(&self) -> Option<Timestamp>
pub fn first_timestamp(&self) -> Option<Timestamp>
Returns the first timestamp in the batch or None
if the batch is empty.
Sourcepub fn last_timestamp(&self) -> Option<Timestamp>
pub fn last_timestamp(&self) -> Option<Timestamp>
Returns the last timestamp in the batch or None
if the batch is empty.
Sourcepub fn first_sequence(&self) -> Option<SequenceNumber>
pub fn first_sequence(&self) -> Option<SequenceNumber>
Returns the first sequence in the batch or None
if the batch is empty.
Sourcepub fn last_sequence(&self) -> Option<SequenceNumber>
pub fn last_sequence(&self) -> Option<SequenceNumber>
Returns the last sequence in the batch or None
if the batch is empty.
Sourcepub fn set_primary_key(&mut self, primary_key: Vec<u8>)
pub fn set_primary_key(&mut self, primary_key: Vec<u8>)
Replaces the primary key of the batch.
Notice that this Batch also contains a maybe-exist pk_values
.
Be sure to update that field as well.
Sourcepub fn concat(batches: Vec<Batch>) -> Result<Batch>
pub fn concat(batches: Vec<Batch>) -> Result<Batch>
Takes batches
and concat them into one batch.
All batches
must have the same primary key.
Sourcepub fn filter_deleted(&mut self) -> Result<()>
pub fn filter_deleted(&mut self) -> Result<()>
Removes rows whose op type is delete.
pub fn filter(&mut self, predicate: &BooleanVector) -> Result<()>
Sourcepub fn filter_by_sequence(
&mut self,
sequence: Option<SequenceNumber>,
) -> Result<()>
pub fn filter_by_sequence( &mut self, sequence: Option<SequenceNumber>, ) -> Result<()>
Filters rows by the given sequence
. Only preserves rows with sequence less than or equal to sequence
.
Sourcepub fn sort(&mut self, dedup: bool) -> Result<()>
pub fn sort(&mut self, dedup: bool) -> Result<()>
Sorts rows in the batch. If dedup
is true, it also removes
duplicated rows according to primary keys.
It orders rows by timestamp, sequence desc and only keep the latest row for the same timestamp. It doesn’t consider op type as sequence should already provide uniqueness for a row.
Sourcepub fn memory_size(&self) -> usize
pub fn memory_size(&self) -> usize
Returns the estimated memory size of the batch.
Sourcepub(crate) fn projected_fields(
metadata: &RegionMetadata,
projection: &[ColumnId],
) -> Vec<(ColumnId, ConcreteDataType)>
pub(crate) fn projected_fields( metadata: &RegionMetadata, projection: &[ColumnId], ) -> Vec<(ColumnId, ConcreteDataType)>
Returns ids and datatypes of fields in the Batch after applying the projection
.
Sourcepub(crate) fn timestamps_native(&self) -> Option<&[i64]>
pub(crate) fn timestamps_native(&self) -> Option<&[i64]>
Returns timestamps in a native slice or None
if the batch is empty.
Sourcefn take_in_place(&mut self, indices: &UInt32Vector) -> Result<()>
fn take_in_place(&mut self, indices: &UInt32Vector) -> Result<()>
Takes the batch in place.
Sourcefn get_timestamp(&self, index: usize) -> Timestamp
fn get_timestamp(&self, index: usize) -> Timestamp
Gets a timestamp at given index
.
§Panics
Panics if index
is out-of-bound or the timestamp vector returns null.
Sourcepub(crate) fn get_sequence(&self, index: usize) -> SequenceNumber
pub(crate) fn get_sequence(&self, index: usize) -> SequenceNumber
Gets a sequence at given index
.
§Panics
Panics if index
is out-of-bound or the sequence vector returns null.
Sourcepub(crate) fn check_monotonic(&self) -> Result<(), String>
pub(crate) fn check_monotonic(&self) -> Result<(), String>
Checks the batch is monotonic by timestamps.
Sourcepub(crate) fn check_next_batch(&self, other: &Batch) -> Result<(), String>
pub(crate) fn check_next_batch(&self, other: &Batch) -> Result<(), String>
Returns Ok if the given batch is behind the current batch.
Sourcepub fn pk_col_value(
&mut self,
codec: &dyn PrimaryKeyCodec,
col_idx_in_pk: usize,
column_id: ColumnId,
) -> Result<Option<&Value>>
pub fn pk_col_value( &mut self, codec: &dyn PrimaryKeyCodec, col_idx_in_pk: usize, column_id: ColumnId, ) -> Result<Option<&Value>>
Returns the value of the column in the primary key.
Lazily decodes the primary key and caches the result.
Sourcepub fn field_col_value(&mut self, column_id: ColumnId) -> Option<&BatchColumn>
pub fn field_col_value(&mut self, column_id: ColumnId) -> Option<&BatchColumn>
Returns values of the field in the batch.
Lazily caches the field index.
Trait Implementations§
Source§impl From<Batch> for BatchBuilder
impl From<Batch> for BatchBuilder
impl StructuralPartialEq for Batch
Auto Trait Implementations§
impl Freeze for Batch
impl !RefUnwindSafe for Batch
impl Send for Batch
impl Sync for Batch
impl Unpin for Batch
impl !UnwindSafe for Batch
Blanket Implementations§
§impl<T> AnySync for T
impl<T> AnySync for T
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,
§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<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.§impl<T> DowncastSync for T
impl<T> DowncastSync for T
§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> Pointable for T
impl<T> Pointable for T
§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
self
from the equivalent element of its
superset. Read more§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
self
is actually part of its subset T
(and can be converted to it).§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
self.to_subset
but without any property checks. Always succeeds.§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
self
to the equivalent element of its superset.§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.