Expand description
Contains traits responsible for the actual construction of SQL statements
The types in this module are part of Diesel’s public API, but are generally only useful for implementing Diesel plugins. Applications should generally not need to care about the types inside of this module.
Modules§
- bind_collector 
- Types related to managing bind parameters during query construction.
Structs§
- Alli-implement-a-third-party-backend-and-opt-into-breaking-changes
- Keep duplicate rows in the result
- AstPass
- The primary type used when walking a Diesel AST during query execution.
- AstPassToSql Options i-implement-a-third-party-backend-and-opt-into-breaking-changes
- This is used to pass down additional settings to the AstPasswhen rendering the sql string.
- BatchInsert i-implement-a-third-party-backend-and-opt-into-breaking-changes
- This type represents a batch insert clause, which allows to insert multiple rows at once.
- BoxedLimit Offset Clause i-implement-a-third-party-backend-and-opt-into-breaking-changes
- A boxed variant of LimitOffsetClause
- BoxedSelect Statement i-implement-a-third-party-backend-and-opt-into-breaking-changes
- This type represents a boxed select query
- BoxedSqlQuery 
- See SqlQuery::into_boxed.
- CollectedQuery i-implement-a-third-party-backend-and-opt-into-breaking-changes
- A SQL query variant with already collected bind data which can be moved
- DebugQuery 
- A struct that implements fmt::Displayandfmt::Debugto show the SQL representation of a query.
- DefaultValues i-implement-a-third-party-backend-and-opt-into-breaking-changes
- DeleteStatement 
- Represents a SQL DELETEstatement.
- Distincti-implement-a-third-party-backend-and-opt-into-breaking-changes
- Remove duplicate rows in the result, this is the default behavior of UNION,INTERSECTandEXCEPT
- Excepti-implement-a-third-party-backend-and-opt-into-breaking-changes
- Computes the set difference of the rows returned by the involved SELECTstatements using SQLEXCEPT
- FromClause i-implement-a-third-party-backend-and-opt-into-breaking-changes
- IncompleteInsert Statement 
- The structure returned by insert_into.
- InsertOrIgnore i-implement-a-third-party-backend-and-opt-into-breaking-changes
- A marker type for insert or ignore statements
- InsertStatement i-implement-a-third-party-backend-and-opt-into-breaking-changes
- A fully constructed insert statement.
- Intersecti-implement-a-third-party-backend-and-opt-into-breaking-changes
- Computes the set intersection of the rows returned by the involved SELECTstatements using SQLINTERSECT
- LimitClause i-implement-a-third-party-backend-and-opt-into-breaking-changes
- A query node representing a limit clause
- LimitOffset Clause i-implement-a-third-party-backend-and-opt-into-breaking-changes
- A helper query node that contains both limit and offset clauses
- NoFromClause i-implement-a-third-party-backend-and-opt-into-breaking-changes
- This type represents a not existing from clause
- NoLimitClause i-implement-a-third-party-backend-and-opt-into-breaking-changes
- A query node indicating the absence of a limit clause
- NoOffsetClause i-implement-a-third-party-backend-and-opt-into-breaking-changes
- A query node indicating the absence of an offset clause
- NoOrderClause i-implement-a-third-party-backend-and-opt-into-breaking-changes
- DSL node that represents that no order clause is set
- OffsetClause i-implement-a-third-party-backend-and-opt-into-breaking-changes
- A query node representing an offset clause
- Onlypostgres_backend
- Represents a query with an ONLYclause.
- OrderClause i-implement-a-third-party-backend-and-opt-into-breaking-changes
- DSL node that represents that an order clause is set
- ParenthesisWrapper i-implement-a-third-party-backend-and-opt-into-breaking-changes
- Wrapper used to wrap rhs sql in parenthesis when supported by backend
- Replacei-implement-a-third-party-backend-and-opt-into-breaking-changes
- A marker type for replace statements
- ReturningClause i-implement-a-third-party-backend-and-opt-into-breaking-changes
- This type represents a SQL Returningclause
- SelectStatement i-implement-a-third-party-backend-and-opt-into-breaking-changes
- This type represents a select query
- SqlQuery
- The return value of sql_query.
- Tablesamplepostgres_backend
- Represents a query with a TABLESAMPLEclause.
- Unioni-implement-a-third-party-backend-and-opt-into-breaking-changes
- Computes the set union of the rows returned by the involved SELECTstatements using SQLUNION
- UpdateStatement 
- Represents a complete UPDATEstatement.
- UpdateTarget 
- ValuesClause i-implement-a-third-party-backend-and-opt-into-breaking-changes
- This type represents a values clause used as part of insert statements
Traits§
- AsChangeset
- Types which can be passed to
update.set.
- AsQuery
- Types that can be converted into a complete, typed SQL query.
- BindCollector 
- A type which manages serializing bind parameters during query construction.
- DecoratableTarget 
- Interface to add information to conflict targets. Designed to be open for further additions to conflict targets like constraints
- IntoBoxed Clause 
- A trait used to construct type erased boxed variant of the current query node
- IntoUpdate Target 
- A type which can be passed to updateordelete.
- MoveableBind Collector i-implement-a-third-party-backend-and-opt-into-breaking-changes
- A movable version of the bind collector which allows it to be extracted, moved and refilled.
- Query
- A complete SQL query with a return type.
- QueryBuilder 
- Constructs a SQL query from a Diesel AST.
- QueryFragment 
- An untyped fragment of SQL.
- QueryId
- Uniquely identifies queries by their type for the purpose of prepared statement caching.
- SelectClause Expression i-implement-a-third-party-backend-and-opt-into-breaking-changes
- Specialised variant of Expressionfor select clause types
- SelectQuery 
- Indicates that a type is a SELECTstatement.
- SupportsCombination Clause i-implement-a-third-party-backend-and-opt-into-breaking-changes
- Marker trait used to indicate whenever a backend supports given combination
- UndecoratedInsert Record i-implement-a-third-party-backend-and-opt-into-breaking-changes
- Marker trait to indicate that no additional operations have been added to a record for insert.
Functions§
- debug_query 
- Takes a query QueryFragmentexpression as an argument and returns a type that implementsfmt::Displayandfmt::Debugto show the query.
Type Aliases§
- BoxedDelete Statement 
- A DELETEstatement with a boxedWHEREclause
- BoxedUpdate Statement 
- An UPDATEstatement with a boxedWHEREclause.
- BuildQuery Result 
- A specialized Result type used with the query builder.
- IncompleteInsert OrIgnore Statement 
- Represents the return type of diesel::insert_or_ignore_into
- IncompleteReplace Statement 
- Represents the return type of diesel::replace_into
- InsertOrIgnore Statement 
- Represents a complete INSERT OR IGNOREstatement.
- ReplaceStatement 
- Represents a complete INSERT OR REPLACEstatement.
Derive Macros§
- AsChangeset
- Implements AsChangeset
- QueryId
- Implements QueryId