connectorx::sources

Trait SourcePartition

Source
pub trait SourcePartition {
    type TypeSystem: TypeSystem;
    type Parser<'a>: PartitionParser<'a, TypeSystem = Self::TypeSystem, Error = Self::Error>
       where Self: 'a;
    type Error: From<ConnectorXError> + Send + Debug;

    // Required methods
    fn result_rows(&mut self) -> Result<(), Self::Error>;
    fn parser(&mut self) -> Result<Self::Parser<'_>, Self::Error>;
    fn nrows(&self) -> usize;
    fn ncols(&self) -> usize;
}
Expand description

In general, a DataSource abstracts the data source as a stream, which can produce a sequence of values of variate types by repetitively calling the function produce.

Required Associated Types§

Source

type TypeSystem: TypeSystem

Source

type Parser<'a>: PartitionParser<'a, TypeSystem = Self::TypeSystem, Error = Self::Error> where Self: 'a

Source

type Error: From<ConnectorXError> + Send + Debug

Required Methods§

Source

fn result_rows(&mut self) -> Result<(), Self::Error>

Count total number of rows in each partition.

Source

fn parser(&mut self) -> Result<Self::Parser<'_>, Self::Error>

Source

fn nrows(&self) -> usize

Number of rows this DataSource got. Sometimes it is not possible for the source to know how many rows it gets before reading the whole data.

Source

fn ncols(&self) -> usize

Number of cols this DataSource got.

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.

Implementors§

Source§

impl SourcePartition for BigQuerySourcePartition

Source§

impl SourcePartition for CSVSourcePartition

Source§

impl SourcePartition for DummySourcePartition

Source§

impl SourcePartition for MsSQLSourcePartition

Source§

impl SourcePartition for MySQLSourcePartition<BinaryProtocol>

Source§

impl SourcePartition for MySQLSourcePartition<TextProtocol>

Source§

impl SourcePartition for OracleSourcePartition

Source§

impl SourcePartition for SQLiteSourcePartition

Source§

impl SourcePartition for TrinoSourcePartition

Source§

impl<C> SourcePartition for PostgresSourcePartition<BinaryProtocol, C>
where C: MakeTlsConnect<Socket> + Clone + 'static + Sync + Send, C::TlsConnect: Send, C::Stream: Send, <C::TlsConnect as TlsConnect<Socket>>::Future: Send,

Source§

impl<C> SourcePartition for PostgresSourcePartition<CSVProtocol, C>
where C: MakeTlsConnect<Socket> + Clone + 'static + Sync + Send, C::TlsConnect: Send, C::Stream: Send, <C::TlsConnect as TlsConnect<Socket>>::Future: Send,

Source§

impl<C> SourcePartition for PostgresSourcePartition<CursorProtocol, C>
where C: MakeTlsConnect<Socket> + Clone + 'static + Sync + Send, C::TlsConnect: Send, C::Stream: Send, <C::TlsConnect as TlsConnect<Socket>>::Future: Send,

Source§

impl<C> SourcePartition for PostgresSourcePartition<SimpleProtocol, C>
where C: MakeTlsConnect<Socket> + Clone + 'static + Sync + Send, C::TlsConnect: Send, C::Stream: Send, <C::TlsConnect as TlsConnect<Socket>>::Future: Send,