pub struct CreateTableStatement { /* private fields */ }Available on crate feature
database and non-WebAssembly only.Expand description
CREATE TABLE statement builder
This struct provides a fluent API for constructing CREATE TABLE queries.
§Examples
ⓘ
use reinhardt_query::prelude::*;
use reinhardt_query::types::ddl::ColumnType;
let query = Query::create_table()
.table("users")
.if_not_exists()
.col(
ColumnDef::new("id")
.column_type(ColumnType::Integer)
.primary_key(true)
.auto_increment(true)
)
.col(
ColumnDef::new("name")
.column_type(ColumnType::String(Some(100)))
.not_null(true)
);Implementations§
Source§impl CreateTableStatement
impl CreateTableStatement
Sourcepub fn new() -> CreateTableStatement
pub fn new() -> CreateTableStatement
Create a new CREATE TABLE statement
Sourcepub fn take(&mut self) -> CreateTableStatement
pub fn take(&mut self) -> CreateTableStatement
Take the ownership of data in the current CreateTableStatement
Sourcepub fn table<T>(&mut self, tbl: T) -> &mut CreateTableStatementwhere
T: IntoTableRef,
pub fn table<T>(&mut self, tbl: T) -> &mut CreateTableStatementwhere
T: IntoTableRef,
Sourcepub fn if_not_exists(&mut self) -> &mut CreateTableStatement
pub fn if_not_exists(&mut self) -> &mut CreateTableStatement
Sourcepub fn col(&mut self, column: ColumnDef) -> &mut CreateTableStatement
pub fn col(&mut self, column: ColumnDef) -> &mut CreateTableStatement
Sourcepub fn cols<I>(&mut self, columns: I) -> &mut CreateTableStatementwhere
I: IntoIterator<Item = ColumnDef>,
pub fn cols<I>(&mut self, columns: I) -> &mut CreateTableStatementwhere
I: IntoIterator<Item = ColumnDef>,
Add multiple column definitions
§Examples
ⓘ
use reinhardt_query::prelude::*;
use reinhardt_query::types::ddl::{ColumnDef, ColumnType};
let query = Query::create_table()
.table("users")
.cols(vec![
ColumnDef::new("id").column_type(ColumnType::Integer),
ColumnDef::new("name").column_type(ColumnType::String(Some(100))),
]);Sourcepub fn constraint(
&mut self,
constraint: TableConstraint,
) -> &mut CreateTableStatement
pub fn constraint( &mut self, constraint: TableConstraint, ) -> &mut CreateTableStatement
Sourcepub fn constraints<I>(&mut self, constraints: I) -> &mut CreateTableStatementwhere
I: IntoIterator<Item = TableConstraint>,
pub fn constraints<I>(&mut self, constraints: I) -> &mut CreateTableStatementwhere
I: IntoIterator<Item = TableConstraint>,
Add multiple table constraints
§Examples
ⓘ
use reinhardt_query::prelude::*;
use reinhardt_query::types::ddl::TableConstraint;
let query = Query::create_table()
.table("order_items")
.constraints(vec![
TableConstraint::PrimaryKey {
name: None,
columns: vec!["order_id".into(), "item_id".into()],
},
TableConstraint::ForeignKey {
name: Some("fk_order".into()),
columns: vec!["order_id".into()],
ref_table: Box::new("orders".into()),
ref_columns: vec!["id".into()],
on_delete: None,
on_update: None,
},
]);Sourcepub fn index(&mut self, index: IndexDef) -> &mut CreateTableStatement
pub fn index(&mut self, index: IndexDef) -> &mut CreateTableStatement
Sourcepub fn indexes<I>(&mut self, indexes: I) -> &mut CreateTableStatementwhere
I: IntoIterator<Item = IndexDef>,
pub fn indexes<I>(&mut self, indexes: I) -> &mut CreateTableStatementwhere
I: IntoIterator<Item = IndexDef>,
Add multiple index definitions
Sourcepub fn comment<S>(&mut self, comment: S) -> &mut CreateTableStatement
pub fn comment<S>(&mut self, comment: S) -> &mut CreateTableStatement
Sourcepub fn primary_key<I, C>(&mut self, columns: I) -> &mut CreateTableStatementwhere
I: IntoIterator<Item = C>,
C: IntoIden,
pub fn primary_key<I, C>(&mut self, columns: I) -> &mut CreateTableStatementwhere
I: IntoIterator<Item = C>,
C: IntoIden,
Sourcepub fn unique<I, C>(&mut self, columns: I) -> &mut CreateTableStatementwhere
I: IntoIterator<Item = C>,
C: IntoIden,
pub fn unique<I, C>(&mut self, columns: I) -> &mut CreateTableStatementwhere
I: IntoIterator<Item = C>,
C: IntoIden,
Sourcepub fn foreign_key<I1, C1, T, I2, C2>(
&mut self,
columns: I1,
ref_table: T,
ref_columns: I2,
on_delete: Option<ForeignKeyAction>,
on_update: Option<ForeignKeyAction>,
) -> &mut CreateTableStatementwhere
I1: IntoIterator<Item = C1>,
C1: IntoIden,
T: IntoTableRef,
I2: IntoIterator<Item = C2>,
C2: IntoIden,
pub fn foreign_key<I1, C1, T, I2, C2>(
&mut self,
columns: I1,
ref_table: T,
ref_columns: I2,
on_delete: Option<ForeignKeyAction>,
on_update: Option<ForeignKeyAction>,
) -> &mut CreateTableStatementwhere
I1: IntoIterator<Item = C1>,
C1: IntoIden,
T: IntoTableRef,
I2: IntoIterator<Item = C2>,
C2: IntoIden,
Add a foreign key constraint
This is a convenience method for adding a FOREIGN KEY constraint.
§Examples
ⓘ
use reinhardt_query::prelude::*;
use reinhardt_query::types::ddl::ForeignKeyAction;
let query = Query::create_table()
.table("posts")
.foreign_key(
vec!["user_id"],
"users",
vec!["id"],
Some(ForeignKeyAction::Cascade),
None,
);Sourcepub fn foreign_key_from_builder(
&mut self,
fk: &mut ForeignKeyCreateStatement,
) -> &mut CreateTableStatement
pub fn foreign_key_from_builder( &mut self, fk: &mut ForeignKeyCreateStatement, ) -> &mut CreateTableStatement
Add a foreign key constraint from a ForeignKeyCreateStatement builder.
This method accepts the builder-pattern style used by
ForeignKey::create().
§Examples
ⓘ
use reinhardt_query::prelude::*;
let mut fk = ForeignKey::create();
fk.from_tbl(Alias::new("posts"))
.from_col(Alias::new("user_id"))
.to_tbl(Alias::new("users"))
.to_col(Alias::new("id"));
let mut stmt = Query::create_table();
stmt.table("posts")
.foreign_key_from_builder(&mut fk);Trait Implementations§
Source§impl Clone for CreateTableStatement
impl Clone for CreateTableStatement
Source§fn clone(&self) -> CreateTableStatement
fn clone(&self) -> CreateTableStatement
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for CreateTableStatement
impl Debug for CreateTableStatement
Source§impl Default for CreateTableStatement
impl Default for CreateTableStatement
Source§fn default() -> CreateTableStatement
fn default() -> CreateTableStatement
Returns the “default value” for a type. Read more
Source§impl QueryStatementBuilder for CreateTableStatement
impl QueryStatementBuilder for CreateTableStatement
Source§fn build_any(
&self,
query_builder: &(dyn QueryBuilderTrait + 'static),
) -> (String, Values)
fn build_any( &self, query_builder: &(dyn QueryBuilderTrait + 'static), ) -> (String, Values)
Build SQL statement for a database backend and collect query parameters Read more
impl QueryStatementWriter for CreateTableStatement
Auto Trait Implementations§
impl Freeze for CreateTableStatement
impl !RefUnwindSafe for CreateTableStatement
impl Send for CreateTableStatement
impl Sync for CreateTableStatement
impl Unpin for CreateTableStatement
impl UnsafeUnpin for CreateTableStatement
impl !UnwindSafe for CreateTableStatement
Blanket Implementations§
Source§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
Source§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> FmtForward for T
impl<T> FmtForward for T
Source§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
Causes
self to use its Binary implementation when Debug-formatted.Source§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
Causes
self to use its Display implementation when
Debug-formatted.Source§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
Causes
self to use its LowerExp implementation when
Debug-formatted.Source§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
Causes
self to use its LowerHex implementation when
Debug-formatted.Source§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
Causes
self to use its Octal implementation when Debug-formatted.Source§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
Causes
self to use its Pointer implementation when
Debug-formatted.Source§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
Causes
self to use its UpperExp implementation when
Debug-formatted.Source§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
Causes
self to use its UpperHex implementation when
Debug-formatted.Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
Source§fn in_current_span(self) -> Instrumented<Self> ⓘ
fn in_current_span(self) -> Instrumented<Self> ⓘ
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T in a tonic::RequestSource§impl<T> IntoResult<T> for T
impl<T> IntoResult<T> for T
type Err = Infallible
fn into_result(self) -> Result<T, <T as IntoResult<T>>::Err>
Creates a shared type from an unshared type.
Source§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
Source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
Pipes by value. This is generally the method you want to use. Read more
Source§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
Borrows
self and passes that borrow into the pipe function. Read moreSource§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
Mutably borrows
self and passes that borrow into the pipe function. Read moreSource§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
Source§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
Source§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
Borrows
self, then passes self.as_ref() into the pipe function.Source§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
Mutably borrows
self, then passes self.as_mut() into the pipe
function.Source§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
Borrows
self, then passes self.deref() into the pipe function.Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
Source§impl<R, P> ReadPrimitive<R> for P
impl<R, P> ReadPrimitive<R> for P
Source§fn read_from_little_endian(read: &mut R) -> Result<Self, Error>
fn read_from_little_endian(read: &mut R) -> Result<Self, Error>
Read this value from the supplied reader. Same as
ReadEndian::read_from_little_endian().Source§impl<E> ServerFnErrorAssertions<E> for Ewhere
E: Debug,
impl<E> ServerFnErrorAssertions<E> for Ewhere
E: Debug,
Source§fn should_contain_message(&self, expected: &str)where
E: Display,
fn should_contain_message(&self, expected: &str)where
E: Display,
Assert that the error message contains the specified text.
Source§fn should_have_message(&self, expected: &str)where
E: Display,
fn should_have_message(&self, expected: &str)where
E: Display,
Assert that the error message matches exactly.
Source§impl<T> Tap for T
impl<T> Tap for T
Source§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Immutable access to the
Borrow<B> of a value. Read moreSource§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
Mutable access to the
BorrowMut<B> of a value. Read moreSource§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
Immutable access to the
AsRef<R> view of a value. Read moreSource§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
Mutable access to the
AsMut<R> view of a value. Read moreSource§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Immutable access to the
Deref::Target of a value. Read moreSource§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Mutable access to the
Deref::Target of a value. Read moreSource§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
Calls
.tap() only in debug builds, and is erased in release builds.Source§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
Calls
.tap_mut() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
Calls
.tap_borrow() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
Calls
.tap_borrow_mut() only in debug builds, and is erased in release
builds.Source§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
Calls
.tap_ref() only in debug builds, and is erased in release
builds.Source§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
Calls
.tap_ref_mut() only in debug builds, and is erased in release
builds.Source§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
Calls
.tap_deref() only in debug builds, and is erased in release
builds.