Struct diesel::query_builder::BatchInsert
source · 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, 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 as HasBindCollector<'b>>::BindCollector,
metadata_lookup: &mut DB::MetadataLookup,
backend: &'b DB
) -> QueryResult<()>
fn collect_binds<'b>( &'b self, out: &mut <DB as HasBindCollector<'b>>::BindCollector, 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> RefUnwindSafe for BatchInsert<V, Tab, QId, STABLE_QUERY_ID>where QId: RefUnwindSafe, Tab: RefUnwindSafe, V: RefUnwindSafe,
impl<V, Tab, QId, const STABLE_QUERY_ID: bool> Send for BatchInsert<V, Tab, QId, STABLE_QUERY_ID>where QId: Send, Tab: Send, V: Send,
impl<V, Tab, QId, const STABLE_QUERY_ID: bool> Sync for BatchInsert<V, Tab, QId, STABLE_QUERY_ID>where QId: Sync, Tab: Sync, V: Sync,
impl<V, Tab, QId, const STABLE_QUERY_ID: bool> Unpin for BatchInsert<V, Tab, QId, STABLE_QUERY_ID>where QId: Unpin, Tab: Unpin, V: Unpin,
impl<V, Tab, QId, const STABLE_QUERY_ID: bool> UnwindSafe for BatchInsert<V, Tab, QId, STABLE_QUERY_ID>where QId: UnwindSafe, Tab: UnwindSafe, V: UnwindSafe,
Blanket Implementations§
source§impl<Conn, DB, T> ExecuteDsl<Conn, DB> for Twhere
Conn: Connection<Backend = DB>,
DB: Backend,
T: QueryFragment<DB, NotSpecialized> + QueryId,
impl<Conn, DB, T> ExecuteDsl<Conn, DB> for Twhere Conn: Connection<Backend = DB>, DB: Backend, T: QueryFragment<DB, NotSpecialized> + QueryId,
source§impl<T> IntoSql for T
impl<T> IntoSql for T
source§fn into_sql<T>(self) -> AsExprOf<Self, T>where
Self: AsExpression<T> + Sized,
T: SqlType + TypedExpressionType,
fn into_sql<T>(self) -> AsExprOf<Self, T>where Self: AsExpression<T> + Sized, T: SqlType + TypedExpressionType,
Convert
self
to an expression for Diesel’s query builder. Read moresource§fn as_sql<'a, T>(&'a self) -> AsExprOf<&'a Self, T>where
&'a Self: AsExpression<T>,
T: SqlType + TypedExpressionType,
fn as_sql<'a, T>(&'a self) -> AsExprOf<&'a Self, T>where &'a Self: AsExpression<T>, T: SqlType + TypedExpressionType,
Convert
&self
to an expression for Diesel’s query builder. Read more