Skip to main content

CopyOptions

Struct CopyOptions 

Source
pub struct CopyOptions {
    pub source: CopySource,
    pub create_table: bool,
    pub preserve_pk: bool,
    pub if_exists: IfExists,
    pub conflict_key: Vec<String>,
    pub atomic: bool,
    pub batch_size: usize,
    pub bulk_mode: BulkMode,
    pub copy_format: CopyFormat,
    pub verbose: bool,
    pub progress: Option<Box<dyn Fn(usize) + Send>>,
}
Expand description

Options for a copy operation.

Fields§

§source: CopySource§create_table: bool

Translate source column metadata into destination DDL and CREATE TABLE if the target does not exist.

§preserve_pk: bool

When combined with create_table, look up the source table’s declared primary key and include a matching PRIMARY KEY (...) clause in the emitted DDL. Default false preserves the v1 column-only contract. Best-effort: source tables with no declared PK fall through to the column-only DDL. Ignored in --query mode (no canonical source table to inspect).

§if_exists: IfExists

What to do if the target table already exists with rows.

§conflict_key: Vec<String>

User-supplied conflict-key column list, overriding the PK auto-detection used by IfExists::Skip / IfExists::Upsert. Empty = fall back to the destination’s declared primary key. Validated against the source column shape during copy preflight. Ignored for non-conflict strategies (Error/Append/Truncate).

§atomic: bool

Wrap the entire copy in a single target-side transaction.

§batch_size: usize

How many rows per source-side page / target-side INSERT batch.

§bulk_mode: BulkMode

Whether to route batches through the destination backend’s native bulk loader. Default BulkMode::Off preserves Phase 1 behaviour.

§copy_format: CopyFormat

Wire format for the Postgres COPY bulk path. Other backends ignore this field. Default CopyFormat::Text.

§verbose: bool

Whether copy_rows should emit per-event diagnostics on stderr (currently: a one-line “using native path” notice when the bulk path is selected, plus the standard fallback warning in BulkMode::Auto). Mirrors the CLI --verbose flag.

§progress: Option<Box<dyn Fn(usize) + Send>>

Optional progress callback invoked after each batch with the running row count.

Trait Implementations§

Source§

impl Debug for CopyOptions

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for CopyOptions

Source§

fn default() -> Self

Returns the “default value” for a type. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more