pub struct SQL<'a, V: SQLParam> {
pub chunks: SmallVec<[SQLChunk<'a, V>; 8]>,
}Expand description
SQL fragment builder with flat chunk storage.
Uses SmallVec<[SQLChunk; 8]> for inline storage of typical SQL fragments
without heap allocation.
Fields§
§chunks: SmallVec<[SQLChunk<'a, V>; 8]>Implementations§
Source§impl<'a, V: SQLParam> SQL<'a, V>
impl<'a, V: SQLParam> SQL<'a, V>
Sourcepub fn with_capacity_chunks(capacity: usize) -> Self
pub fn with_capacity_chunks(capacity: usize) -> Self
Creates an empty SQL fragment with pre-allocated chunk capacity.
Sourcepub fn bytes(bytes: impl Into<Cow<'a, [u8]>>) -> Self
pub fn bytes(bytes: impl Into<Cow<'a, [u8]>>) -> Self
Creates SQL with a binary parameter value (BLOB/bytea)
Prefer this over SQL::param(Vec<u8>) to avoid list semantics.
Sourcepub fn placeholder(name: &'static str) -> Self
pub fn placeholder(name: &'static str) -> Self
Creates SQL with a named placeholder (no value, for prepared statements)
Sourcepub fn table(table: &'static dyn SQLTableInfo) -> Self
pub fn table(table: &'static dyn SQLTableInfo) -> Self
Creates SQL referencing a table
Sourcepub fn column(column: &'static dyn SQLColumnInfo) -> Self
pub fn column(column: &'static dyn SQLColumnInfo) -> Self
Creates SQL referencing a column
Sourcepub fn func(name: &'static str, args: SQL<'a, V>) -> Self
pub fn func(name: &'static str, args: SQL<'a, V>) -> Self
Creates SQL for a function call: NAME(args) Subqueries are automatically wrapped in parentheses: NAME((SELECT …))
Sourcepub fn append(self, other: impl Into<SQL<'a, V>>) -> Self
pub fn append(self, other: impl Into<SQL<'a, V>>) -> Self
Append another SQL fragment (flat extend)
Sourcepub fn with_capacity(self, additional: usize) -> Self
pub fn with_capacity(self, additional: usize) -> Self
Pre-allocates capacity for additional chunks
Sourcepub fn join<T>(sqls: T, separator: Token) -> SQL<'a, V>
pub fn join<T>(sqls: T, separator: Token) -> SQL<'a, V>
Joins multiple SQL fragments with a separator
Sourcepub fn is_subquery(&self) -> bool
pub fn is_subquery(&self) -> bool
Check if this SQL fragment is a subquery (starts with SELECT)
Sourcepub fn alias(self, name: impl Into<Cow<'a, str>>) -> SQL<'a, V>
pub fn alias(self, name: impl Into<Cow<'a, str>>) -> SQL<'a, V>
Creates an aliased version: self AS “name”
Sourcepub fn param_list<I>(values: I) -> Self
pub fn param_list<I>(values: I) -> Self
Creates a comma-separated list of parameters
Sourcepub fn assignments<I, T>(pairs: I) -> Self
pub fn assignments<I, T>(pairs: I) -> Self
Creates a comma-separated list of column assignments: “col” = ?
Sourcepub fn into_owned(self) -> OwnedSQL<V>
pub fn into_owned(self) -> OwnedSQL<V>
Converts to owned version (consuming self to avoid clone)
Sourcepub fn sql(&self) -> String
pub fn sql(&self) -> String
Returns the SQL string with dialect-appropriate placeholders
Uses $1, $2, ... for PostgreSQL, ? for SQLite/MySQL
Sourcepub fn write_to(&self, buf: &mut impl Write)
pub fn write_to(&self, buf: &mut impl Write)
Write SQL to a buffer with dialect-appropriate placeholders
Uses $1, $2, ... for PostgreSQL, ? or :name for SQLite, ? for MySQL
Named placeholders use :name syntax only for SQLite; PostgreSQL always uses $N
Sourcepub fn write_chunk_to(
&self,
buf: &mut impl Write,
chunk: &SQLChunk<'a, V>,
index: usize,
)
pub fn write_chunk_to( &self, buf: &mut impl Write, chunk: &SQLChunk<'a, V>, index: usize, )
Write a single chunk with pattern detection
Sourcepub fn write_qualified_columns(
&self,
buf: &mut impl Write,
table: &dyn SQLTableInfo,
)
pub fn write_qualified_columns( &self, buf: &mut impl Write, table: &dyn SQLTableInfo, )
Write fully qualified columns
Trait Implementations§
Source§impl<'a, V, T, N, A> AsRef<SQL<'a, V>> for SQLExpr<'a, V, T, N, A>
Provides reference conversion to inner SQL.
impl<'a, V, T, N, A> AsRef<SQL<'a, V>> for SQLExpr<'a, V, T, N, A>
Provides reference conversion to inner SQL.
Source§impl<'a, V: SQLParam, T: DataType, N: Nullability, A: AggregateKind> From<SQLExpr<'a, V, T, N, A>> for SQL<'a, V>
impl<'a, V: SQLParam, T: DataType, N: Nullability, A: AggregateKind> From<SQLExpr<'a, V, T, N, A>> for SQL<'a, V>
Source§impl<'a, V: SQLParam, T> FromIterator<T> for SQL<'a, V>
impl<'a, V: SQLParam, T> FromIterator<T> for SQL<'a, V>
Source§fn from_iter<I: IntoIterator<Item = T>>(iter: I) -> Self
fn from_iter<I: IntoIterator<Item = T>>(iter: I) -> Self
Source§impl<'a, V: SQLParam> IntoIterator for SQL<'a, V>
impl<'a, V: SQLParam> IntoIterator for SQL<'a, V>
Auto Trait Implementations§
impl<'a, V> Freeze for SQL<'a, V>where
V: Freeze,
impl<'a, V> !RefUnwindSafe for SQL<'a, V>
impl<'a, V> Send for SQL<'a, V>
impl<'a, V> Sync for SQL<'a, V>where
V: Sync,
impl<'a, V> Unpin for SQL<'a, V>where
V: Unpin,
impl<'a, V> !UnwindSafe for SQL<'a, V>
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<'a, V, E> ExprExt<'a, V> for E
impl<'a, V, E> ExprExt<'a, V> for E
Source§fn eq<R>(self, other: R) -> SQLExpr<'a, V, Bool, NonNull, Scalar>
fn eq<R>(self, other: R) -> SQLExpr<'a, V, Bool, NonNull, Scalar>
=). Read moreSource§fn ne<R>(self, other: R) -> SQLExpr<'a, V, Bool, NonNull, Scalar>
fn ne<R>(self, other: R) -> SQLExpr<'a, V, Bool, NonNull, Scalar>
<>). Read moreSource§fn gt<R>(self, other: R) -> SQLExpr<'a, V, Bool, NonNull, Scalar>
fn gt<R>(self, other: R) -> SQLExpr<'a, V, Bool, NonNull, Scalar>
>). Read moreSource§fn ge<R>(self, other: R) -> SQLExpr<'a, V, Bool, NonNull, Scalar>
fn ge<R>(self, other: R) -> SQLExpr<'a, V, Bool, NonNull, Scalar>
>=). Read moreSource§fn lt<R>(self, other: R) -> SQLExpr<'a, V, Bool, NonNull, Scalar>
fn lt<R>(self, other: R) -> SQLExpr<'a, V, Bool, NonNull, Scalar>
<). Read moreSource§fn le<R>(self, other: R) -> SQLExpr<'a, V, Bool, NonNull, Scalar>
fn le<R>(self, other: R) -> SQLExpr<'a, V, Bool, NonNull, Scalar>
<=). Read moreSource§fn like<R>(self, pattern: R) -> SQLExpr<'a, V, Bool, NonNull, Scalar>
fn like<R>(self, pattern: R) -> SQLExpr<'a, V, Bool, NonNull, Scalar>
Source§fn not_like<R>(self, pattern: R) -> SQLExpr<'a, V, Bool, NonNull, Scalar>
fn not_like<R>(self, pattern: R) -> SQLExpr<'a, V, Bool, NonNull, Scalar>
Source§fn between<L, H>(self, low: L, high: H) -> SQLExpr<'a, V, Bool, NonNull, Scalar>where
L: Expr<'a, V>,
H: Expr<'a, V>,
Self::SQLType: Compatible<L::SQLType> + Compatible<H::SQLType>,
fn between<L, H>(self, low: L, high: H) -> SQLExpr<'a, V, Bool, NonNull, Scalar>where
L: Expr<'a, V>,
H: Expr<'a, V>,
Self::SQLType: Compatible<L::SQLType> + Compatible<H::SQLType>,
Source§fn not_between<L, H>(
self,
low: L,
high: H,
) -> SQLExpr<'a, V, Bool, NonNull, Scalar>where
L: Expr<'a, V>,
H: Expr<'a, V>,
Self::SQLType: Compatible<L::SQLType> + Compatible<H::SQLType>,
fn not_between<L, H>(
self,
low: L,
high: H,
) -> SQLExpr<'a, V, Bool, NonNull, Scalar>where
L: Expr<'a, V>,
H: Expr<'a, V>,
Self::SQLType: Compatible<L::SQLType> + Compatible<H::SQLType>,
Source§fn in_array<I, R>(self, values: I) -> SQLExpr<'a, V, Bool, NonNull, Scalar>
fn in_array<I, R>(self, values: I) -> SQLExpr<'a, V, Bool, NonNull, Scalar>
Source§impl<T> ToCompactString for Twhere
T: Display,
impl<T> ToCompactString for Twhere
T: Display,
Source§fn try_to_compact_string(&self) -> Result<CompactString, ToCompactStringError>
fn try_to_compact_string(&self) -> Result<CompactString, ToCompactStringError>
ToCompactString::to_compact_string() Read moreSource§fn to_compact_string(&self) -> CompactString
fn to_compact_string(&self) -> CompactString
CompactString. Read more