pub struct TableScan {
pub required_col_idx: Vec<usize>,
pub output_col_idx: Vec<usize>,
pub table_catalog: Arc<TableCatalog>,
pub table_indexes: Vec<Arc<TableIndex>>,
pub vector_indexes: Vec<Arc<VectorIndex>>,
pub predicate: Condition,
pub as_of: Option<AsOf>,
pub ctx: OptimizerContextRef,
}Expand description
TableScan returns contents of a RisingWave Table.
Fields§
§required_col_idx: Vec<usize>Include output_col_idx and columns required in predicate
output_col_idx: Vec<usize>§table_catalog: Arc<TableCatalog>Table Catalog of the upstream table that the descriptor is derived from.
table_indexes: Vec<Arc<TableIndex>>Table Desc (subset of table catalog). Descriptors of all indexes on this table
vector_indexes: Vec<Arc<VectorIndex>>§predicate: ConditionThe pushed down predicates. It refers to column indexes of the table.
as_of: Option<AsOf>syntax FOR SYSTEM_TIME AS OF PROCTIME() is used for temporal join.
syntax FOR SYSTEM_TIME AS OF '1986-10-26 01:21:00' is used for iceberg.
syntax FOR SYSTEM_TIME AS OF 499162860 is used for iceberg.
syntax FOR SYSTEM_VERSION AS OF 10963874102873; is used for iceberg.
ctx: OptimizerContextRefImplementations§
Source§impl TableScan
impl TableScan
pub(crate) fn rewrite_exprs(&mut self, r: &mut dyn ExprRewriter)
pub(crate) fn visit_exprs(&self, v: &mut dyn ExprVisitor)
pub fn table_name(&self) -> &str
Sourcepub fn distribution_key(&self) -> Option<Vec<usize>>
pub fn distribution_key(&self) -> Option<Vec<usize>>
The mapped distribution key of the scan operator.
The column indices in it is the position in the output_col_idx, instead of the position
in all the columns of the table (which is the table’s distribution key).
Return None if the table’s distribution key are not all in the output_col_idx.
Sourcepub fn output_column_ids(&self) -> Vec<ColumnId>
pub fn output_column_ids(&self) -> Vec<ColumnId>
Get the ids of the output columns.
pub fn primary_key(&self) -> &[ColumnOrder]
pub fn watermark_columns(&self) -> WatermarkColumns
pub(crate) fn column_names_with_table_prefix(&self) -> Vec<String>
pub(crate) fn column_names(&self) -> Vec<String>
pub(crate) fn out_fields(&self) -> FixedBitSet
pub(crate) fn order_names(&self) -> Vec<String>
pub(crate) fn order_names_with_table_prefix(&self) -> Vec<String>
Sourcepub fn get_out_column_index_order(&self) -> Order
pub fn get_out_column_index_order(&self) -> Order
Return indices of fields the output is ordered by and corresponding direction
Sourcepub fn i2o_col_mapping(&self) -> ColIndexMapping
pub fn i2o_col_mapping(&self) -> ColIndexMapping
get the Mapping of columnIndex from internal column index to output column index
Sourcepub fn output_and_pk_column_ids(&self) -> Vec<ColumnId>
pub fn output_and_pk_column_ids(&self) -> Vec<ColumnId>
Get the ids of the output columns and primary key columns.
Sourcepub fn to_index_scan(
&self,
index_table_catalog: Arc<TableCatalog>,
primary_to_secondary_mapping: &BTreeMap<usize, usize>,
function_mapping: &HashMap<FunctionCall, usize>,
) -> Self
pub fn to_index_scan( &self, index_table_catalog: Arc<TableCatalog>, primary_to_secondary_mapping: &BTreeMap<usize, usize>, function_mapping: &HashMap<FunctionCall, usize>, ) -> Self
Prerequisite: the caller should guarantee that primary_to_secondary_mapping must cover the
scan.
Sourcepub(crate) fn new(
output_col_idx: Vec<usize>,
table_catalog: Arc<TableCatalog>,
table_indexes: Vec<Arc<TableIndex>>,
vector_indexes: Vec<Arc<VectorIndex>>,
ctx: OptimizerContextRef,
predicate: Condition,
as_of: Option<AsOf>,
) -> Self
pub(crate) fn new( output_col_idx: Vec<usize>, table_catalog: Arc<TableCatalog>, table_indexes: Vec<Arc<TableIndex>>, vector_indexes: Vec<Arc<VectorIndex>>, ctx: OptimizerContextRef, predicate: Condition, as_of: Option<AsOf>, ) -> Self
Create a LogicalScan node. Used internally by optimizer.
pub(crate) fn new_inner( output_col_idx: Vec<usize>, table_catalog: Arc<TableCatalog>, table_indexes: Vec<Arc<TableIndex>>, vector_indexes: Vec<Arc<VectorIndex>>, ctx: OptimizerContextRef, predicate: Condition, as_of: Option<AsOf>, ) -> Self
pub(crate) fn columns_pretty<'a>(&self, verbose: bool) -> Pretty<'a>
pub(crate) fn fields_pretty_schema(&self) -> Schema
pub(crate) fn cross_database(&self) -> bool
Source§impl TableScan
impl TableScan
pub fn get_table_columns(&self) -> &[ColumnCatalog]
pub fn append_only(&self) -> bool
Sourcepub fn column_descs(&self) -> Vec<ColumnDesc>
pub fn column_descs(&self) -> Vec<ColumnDesc>
Get the descs of the output columns.
Sourcepub fn get_id_to_op_idx_mapping(
output_col_idx: &[usize],
table_catalog: &TableCatalog,
) -> HashMap<ColumnId, usize>
pub fn get_id_to_op_idx_mapping( output_col_idx: &[usize], table_catalog: &TableCatalog, ) -> HashMap<ColumnId, usize>
Helper function to create a mapping from column_id to operator_idx
Trait Implementations§
Source§impl From<TableScan> for LogicalScan
impl From<TableScan> for LogicalScan
Source§impl From<TableScan> for LogicalPlanRef
impl From<TableScan> for LogicalPlanRef
Source§impl GenericPlanNode for TableScan
impl GenericPlanNode for TableScan
fn schema(&self) -> Schema
fn stream_key(&self) -> Option<Vec<usize>>
fn ctx(&self) -> OptimizerContextRef
fn functional_dependency(&self) -> FunctionalDependencySet
impl Eq for TableScan
Auto Trait Implementations§
impl Freeze for TableScan
impl !RefUnwindSafe for TableScan
impl !Send for TableScan
impl !Sync for TableScan
impl Unpin for TableScan
impl !UnwindSafe for TableScan
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,
§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>
Source§impl<M> MetricVecRelabelExt for M
impl<M> MetricVecRelabelExt for M
Source§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.Source§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.Source§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
Source§impl<T> SameOrElseExt for Twhere
T: Eq,
impl<T> SameOrElseExt for Twhere
T: Eq,
Source§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.