pub struct StreamMaterialize {
pub base: PlanBase<Stream>,
input: StreamPlanRef,
table: TableCatalog,
staging_table: Option<TableCatalog>,
refresh_progress_table: Option<TableCatalog>,
}Expand description
Materializes a stream.
Fields§
§base: PlanBase<Stream>§input: StreamPlanRefChild of Materialize plan
table: TableCatalog§staging_table: Option<TableCatalog>For refreshable tables, staging table for collecting new data during refresh
refresh_progress_table: Option<TableCatalog>For refreshable tables, progress table for tracking refresh progress
Implementations§
Source§impl StreamMaterialize
impl StreamMaterialize
pub fn new(input: PlanRef, table: TableCatalog) -> Result<Self>
pub fn new_with_staging_and_progress( input: PlanRef, table: TableCatalog, staging_table: Option<TableCatalog>, refresh_progress_table: Option<TableCatalog>, ) -> Result<Self>
Sourcepub fn create(
_: StreamOptimizedLogicalPlanRoot,
name: String,
database_id: u32,
schema_id: u32,
definition: String,
table_type: TableType,
cardinality: Cardinality,
retention_seconds: Option<NonZeroU32>,
) -> Result<Self>
pub fn create( _: StreamOptimizedLogicalPlanRoot, name: String, database_id: u32, schema_id: u32, definition: String, table_type: TableType, cardinality: Cardinality, retention_seconds: Option<NonZeroU32>, ) -> Result<Self>
Create a materialize node, for MATERIALIZED VIEW and INDEX.
When creating index, TableType should be Index. Then, materialize will distribute keys
using user_distributed_by.
Sourcepub fn create_for_table(
input: PlanRef,
name: String,
database_id: u32,
schema_id: u32,
user_distributed_by: RequiredDist,
user_order_by: Order,
columns: Vec<ColumnCatalog>,
definition: String,
conflict_behavior: ConflictBehavior,
version_column_indices: Vec<usize>,
pk_column_indices: Vec<usize>,
row_id_index: Option<usize>,
version: TableVersion,
retention_seconds: Option<NonZeroU32>,
webhook_info: Option<PbWebhookSourceInfo>,
engine: Engine,
refreshable: bool,
) -> Result<Self>
pub fn create_for_table( input: PlanRef, name: String, database_id: u32, schema_id: u32, user_distributed_by: RequiredDist, user_order_by: Order, columns: Vec<ColumnCatalog>, definition: String, conflict_behavior: ConflictBehavior, version_column_indices: Vec<usize>, pk_column_indices: Vec<usize>, row_id_index: Option<usize>, version: TableVersion, retention_seconds: Option<NonZeroU32>, webhook_info: Option<PbWebhookSourceInfo>, engine: Engine, refreshable: bool, ) -> Result<Self>
Create a materialize node, for TABLE.
Different from create, the columns are passed in directly, instead of being derived from
the input. So the column IDs are preserved from the SQL columns binding step and will be
consistent with the source node and DML node.
Sourcefn rewrite_input(
input: PlanRef,
user_distributed_by: RequiredDist,
table_type: TableType,
) -> Result<PlanRef>
fn rewrite_input( input: PlanRef, user_distributed_by: RequiredDist, table_type: TableType, ) -> Result<PlanRef>
Rewrite the input to satisfy the required distribution if necessary, according to the type.
Sourcefn derive_table_catalog(
rewritten_input: PlanRef,
name: String,
database_id: u32,
schema_id: u32,
user_order_by: Order,
columns: Vec<ColumnCatalog>,
definition: String,
conflict_behavior: ConflictBehavior,
version_column_indices: Vec<usize>,
pk_column_indices: Option<Vec<usize>>,
row_id_index: Option<usize>,
table_type: TableType,
version: Option<TableVersion>,
cardinality: Cardinality,
retention_seconds: Option<NonZeroU32>,
create_type: CreateType,
webhook_info: Option<PbWebhookSourceInfo>,
engine: Engine,
refreshable: bool,
) -> Result<TableCatalog>
fn derive_table_catalog( rewritten_input: PlanRef, name: String, database_id: u32, schema_id: u32, user_order_by: Order, columns: Vec<ColumnCatalog>, definition: String, conflict_behavior: ConflictBehavior, version_column_indices: Vec<usize>, pk_column_indices: Option<Vec<usize>>, row_id_index: Option<usize>, table_type: TableType, version: Option<TableVersion>, cardinality: Cardinality, retention_seconds: Option<NonZeroU32>, create_type: CreateType, webhook_info: Option<PbWebhookSourceInfo>, engine: Engine, refreshable: bool, ) -> Result<TableCatalog>
Derive the table catalog with the given arguments.
- The caller must ensure the validity of the given
columns. - The
rewritten_inputshould be generated byrewrite_input.
Sourcefn derive_staging_table_catalog(_: TableCatalog) -> TableCatalog
fn derive_staging_table_catalog(_: TableCatalog) -> TableCatalog
The staging table is a pk-only table.
Sourcefn derive_refresh_progress_table_catalog(table: TableCatalog) -> TableCatalog
fn derive_refresh_progress_table_catalog(table: TableCatalog) -> TableCatalog
The refresh progress table is used to track refresh operation progress.
Simplified Schema: vnode (i32), current_pos… (variable PK from upstream),
is_completed (bool), processed_rows (i64)
Sourcepub fn table(&self) -> &TableCatalog
pub fn table(&self) -> &TableCatalog
Get a reference to the stream materialize’s table.
Sourcepub fn staging_table(&self) -> Option<&TableCatalog>
pub fn staging_table(&self) -> Option<&TableCatalog>
Get a reference to the stream materialize’s staging table.
Sourcepub fn refresh_progress_table(&self) -> Option<&TableCatalog>
pub fn refresh_progress_table(&self) -> Option<&TableCatalog>
Get a reference to the stream materialize’s refresh progress table.
pub fn name(&self) -> &str
Methods from Deref<Target = PlanBase<Stream>>§
pub fn clone_with_new_plan_id(&self) -> Self
Sourcepub fn clone_with_new_distribution(&self, dist: Distribution) -> Self
pub fn clone_with_new_distribution(&self, dist: Distribution) -> Self
Clone the plan node with a new distribution.
Panics if the plan node is not physical.
Trait Implementations§
Source§impl Clone for StreamMaterialize
impl Clone for StreamMaterialize
Source§fn clone(&self) -> StreamMaterialize
fn clone(&self) -> StreamMaterialize
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for StreamMaterialize
impl Debug for StreamMaterialize
Source§impl Deref for StreamMaterialize
impl Deref for StreamMaterialize
Source§impl Distill for StreamMaterialize
impl Distill for StreamMaterialize
Source§impl ExprRewritable<Stream> for StreamMaterialize
impl ExprRewritable<Stream> for StreamMaterialize
fn has_rewritable_expr(&self) -> bool
fn rewrite_exprs(&self, _r: &mut dyn ExprRewriter) -> PlanRef<C>
Source§impl ExprVisitable for StreamMaterialize
impl ExprVisitable for StreamMaterialize
fn visit_exprs(&self, _v: &mut dyn ExprVisitor)
Source§impl Hash for StreamMaterialize
impl Hash for StreamMaterialize
Source§impl PartialEq for StreamMaterialize
impl PartialEq for StreamMaterialize
Source§impl PlanNodeMeta for StreamMaterialize
impl PlanNodeMeta for StreamMaterialize
Source§impl PlanTreeNode<Stream> for StreamMaterialize
impl PlanTreeNode<Stream> for StreamMaterialize
Source§impl PlanTreeNodeUnary<Stream> for StreamMaterialize
impl PlanTreeNodeUnary<Stream> for StreamMaterialize
fn input(&self) -> PlanRef
fn clone_with_input(&self, input: PlanRef) -> Self
Source§fn rewrite_with_input(
&self,
_input: PlanRef<C>,
_input_col_change: ColIndexMapping,
) -> (Self, ColIndexMapping)where
Self: Sized,
fn rewrite_with_input(
&self,
_input: PlanRef<C>,
_input_col_change: ColIndexMapping,
) -> (Self, ColIndexMapping)where
Self: Sized,
Source§impl StreamNode for StreamMaterialize
impl StreamNode for StreamMaterialize
fn to_stream_prost_body( &self, state: &mut BuildFragmentGraphState, ) -> PbNodeBody
impl Eq for StreamMaterialize
impl StreamPlanNode for StreamMaterialize
impl StructuralPartialEq for StreamMaterialize
Auto Trait Implementations§
impl Freeze for StreamMaterialize
impl !RefUnwindSafe for StreamMaterialize
impl !Send for StreamMaterialize
impl !Sync for StreamMaterialize
impl Unpin for StreamMaterialize
impl !UnwindSafe for StreamMaterialize
Blanket Implementations§
Source§impl<P> AnyPlanNodeMeta<<P as PlanNodeMeta>::Convention> for Pwhere
P: PlanNodeMeta,
impl<P> AnyPlanNodeMeta<<P as PlanNodeMeta>::Convention> for Pwhere
P: PlanNodeMeta,
fn node_type( &self, ) -> <<P as PlanNodeMeta>::Convention as ConventionMarker>::PlanNodeType
fn plan_base(&self) -> &PlanBase<<P as PlanNodeMeta>::Convention>
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> 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>, which can then be
downcast into Box<dyn 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>, which 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<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> 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 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§impl<T> IntoResult<T> for T
impl<T> IntoResult<T> for T
type Err = Infallible
fn into_result(self) -> Result<T, <T as IntoResult<T>>::Err>
§impl<M> MetricVecRelabelExt for M
impl<M> MetricVecRelabelExt for M
§fn relabel(
self,
metric_level: MetricLevel,
relabel_threshold: MetricLevel,
) -> RelabeledMetricVec<M>
fn relabel( self, metric_level: MetricLevel, relabel_threshold: MetricLevel, ) -> RelabeledMetricVec<M>
RelabeledMetricVec::with_metric_level].§fn relabel_n(
self,
metric_level: MetricLevel,
relabel_threshold: MetricLevel,
relabel_num: usize,
) -> RelabeledMetricVec<M>
fn relabel_n( self, metric_level: MetricLevel, relabel_threshold: MetricLevel, relabel_num: usize, ) -> RelabeledMetricVec<M>
RelabeledMetricVec::with_metric_level_relabel_n].§fn relabel_debug_1(
self,
relabel_threshold: MetricLevel,
) -> RelabeledMetricVec<M>
fn relabel_debug_1( self, relabel_threshold: MetricLevel, ) -> RelabeledMetricVec<M>
RelabeledMetricVec::with_metric_level_relabel_n] with metric_level set to
MetricLevel::Debug and relabel_num set to 1.§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<T> SameOrElseExt for Twhere
T: Eq,
impl<T> SameOrElseExt for Twhere
T: Eq,
§fn same_or_else(self, other: T, f: impl FnOnce() -> T) -> T
fn same_or_else(self, other: T, f: impl FnOnce() -> T) -> T
self and other are equal, if so, return self, otherwise return the result of f().§impl<T> Scope for T
impl<T> Scope for T
§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.