pub struct BatchInsert<V, Tab, QId, const STABLE_QUERY_ID: bool> {
pub values: V,
/* private fields */
}
Available on crate feature
i-implement-a-third-party-backend-and-opt-into-breaking-changes
only.Expand description
This type represents a batch insert clause, which allows to insert multiple rows at once.
Custom backends can specialize the QueryFragment
implementation via SqlDialect::BatchInsertSupport
or provide fully custom ExecuteDsl
and LoadQuery
implementations
Fields§
§values: V
List of values that should be inserted
Trait Implementations§
Source§impl<V: Debug, Tab: Debug, QId: Debug, const STABLE_QUERY_ID: bool> Debug for BatchInsert<V, Tab, QId, STABLE_QUERY_ID>
impl<V: Debug, Tab: Debug, QId: Debug, const STABLE_QUERY_ID: bool> Debug for BatchInsert<V, Tab, QId, STABLE_QUERY_ID>
Source§impl<Tab, DB, V, QId, const HAS_STATIC_QUERY_ID: bool> QueryFragment<DB> for BatchInsert<V, Tab, QId, HAS_STATIC_QUERY_ID>
impl<Tab, DB, V, QId, const HAS_STATIC_QUERY_ID: bool> QueryFragment<DB> for BatchInsert<V, Tab, QId, HAS_STATIC_QUERY_ID>
Source§fn walk_ast<'b>(&'b self, pass: AstPass<'_, 'b, DB>) -> QueryResult<()>
fn walk_ast<'b>(&'b self, pass: AstPass<'_, 'b, DB>) -> QueryResult<()>
Walk over this
QueryFragment
for all passes. Read moreSource§fn to_sql(&self, out: &mut DB::QueryBuilder, backend: &DB) -> QueryResult<()>
fn to_sql(&self, out: &mut DB::QueryBuilder, backend: &DB) -> QueryResult<()>
Available on crate feature
i-implement-a-third-party-backend-and-opt-into-breaking-changes
only.Converts this
QueryFragment
to its SQL representation. Read moreSource§fn collect_binds<'b>(
&'b self,
out: &mut DB::BindCollector<'b>,
metadata_lookup: &mut DB::MetadataLookup,
backend: &'b DB,
) -> QueryResult<()>
fn collect_binds<'b>( &'b self, out: &mut DB::BindCollector<'b>, metadata_lookup: &mut DB::MetadataLookup, backend: &'b DB, ) -> QueryResult<()>
Available on crate feature
i-implement-a-third-party-backend-and-opt-into-breaking-changes
only.Serializes all bind parameters in this query. Read more
Source§fn is_safe_to_cache_prepared(&self, backend: &DB) -> QueryResult<bool>
fn is_safe_to_cache_prepared(&self, backend: &DB) -> QueryResult<bool>
Available on crate feature
i-implement-a-third-party-backend-and-opt-into-breaking-changes
only.Is this query safe to store in the prepared statement cache? Read more
Source§impl<Tab, DB, V, QId, const HAS_STATIC_QUERY_ID: bool> QueryFragment<DB, PostgresLikeBatchInsertSupport> for BatchInsert<Vec<ValuesClause<V, Tab>>, Tab, QId, HAS_STATIC_QUERY_ID>where
DB: Backend + SqlDialect<BatchInsertSupport = PostgresLikeBatchInsertSupport>,
DB::InsertWithDefaultKeyword: SupportsDefaultKeyword,
ValuesClause<V, Tab>: QueryFragment<DB>,
V: QueryFragment<DB>,
impl<Tab, DB, V, QId, const HAS_STATIC_QUERY_ID: bool> QueryFragment<DB, PostgresLikeBatchInsertSupport> for BatchInsert<Vec<ValuesClause<V, Tab>>, Tab, QId, HAS_STATIC_QUERY_ID>where
DB: Backend + SqlDialect<BatchInsertSupport = PostgresLikeBatchInsertSupport>,
DB::InsertWithDefaultKeyword: SupportsDefaultKeyword,
ValuesClause<V, Tab>: QueryFragment<DB>,
V: QueryFragment<DB>,
Source§fn walk_ast<'b>(&'b self, out: AstPass<'_, 'b, DB>) -> QueryResult<()>
fn walk_ast<'b>(&'b self, out: AstPass<'_, 'b, DB>) -> QueryResult<()>
Walk over this
QueryFragment
for all passes. Read moreSource§fn to_sql(&self, out: &mut DB::QueryBuilder, backend: &DB) -> QueryResult<()>
fn to_sql(&self, out: &mut DB::QueryBuilder, backend: &DB) -> QueryResult<()>
Available on crate feature
i-implement-a-third-party-backend-and-opt-into-breaking-changes
only.Converts this
QueryFragment
to its SQL representation. Read moreSource§fn collect_binds<'b>(
&'b self,
out: &mut DB::BindCollector<'b>,
metadata_lookup: &mut DB::MetadataLookup,
backend: &'b DB,
) -> QueryResult<()>
fn collect_binds<'b>( &'b self, out: &mut DB::BindCollector<'b>, metadata_lookup: &mut DB::MetadataLookup, backend: &'b DB, ) -> QueryResult<()>
Available on crate feature
i-implement-a-third-party-backend-and-opt-into-breaking-changes
only.Serializes all bind parameters in this query. Read more
Source§fn is_safe_to_cache_prepared(&self, backend: &DB) -> QueryResult<bool>
fn is_safe_to_cache_prepared(&self, backend: &DB) -> QueryResult<bool>
Available on crate feature
i-implement-a-third-party-backend-and-opt-into-breaking-changes
only.Is this query safe to store in the prepared statement cache? Read more
Source§impl<V, QId: 'static, Tab: 'static, const STABLE_QUERY_ID: bool> QueryId for BatchInsert<V, Tab, QId, STABLE_QUERY_ID>
impl<V, QId: 'static, Tab: 'static, const STABLE_QUERY_ID: bool> QueryId for BatchInsert<V, Tab, QId, STABLE_QUERY_ID>
Source§const HAS_STATIC_QUERY_ID: bool = STABLE_QUERY_ID
const HAS_STATIC_QUERY_ID: bool = STABLE_QUERY_ID
Can the SQL generated by
Self
be uniquely identified by its type? Read moreimpl<T, Table, QId, const STATIC_QUERY_ID: bool> UndecoratedInsertRecord<Table> for BatchInsert<T, Table, QId, STATIC_QUERY_ID>where
T: UndecoratedInsertRecord<Table>,
Auto Trait Implementations§
impl<V, Tab, QId, const STABLE_QUERY_ID: bool> Freeze for BatchInsert<V, Tab, QId, STABLE_QUERY_ID>where
V: Freeze,
impl<V, Tab, QId, const STABLE_QUERY_ID: bool> RefUnwindSafe for BatchInsert<V, Tab, QId, STABLE_QUERY_ID>
impl<V, Tab, QId, const STABLE_QUERY_ID: bool> Send for BatchInsert<V, Tab, QId, STABLE_QUERY_ID>
impl<V, Tab, QId, const STABLE_QUERY_ID: bool> Sync for BatchInsert<V, Tab, QId, STABLE_QUERY_ID>
impl<V, Tab, QId, const STABLE_QUERY_ID: bool> Unpin for BatchInsert<V, Tab, QId, STABLE_QUERY_ID>
impl<V, Tab, QId, const STABLE_QUERY_ID: bool> UnwindSafe for BatchInsert<V, Tab, QId, STABLE_QUERY_ID>
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
Mutably borrows from an owned value. Read more