sea_query/foreign_key/drop.rs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73
use inherent::inherent;
use crate::{backend::SchemaBuilder, types::*, SchemaStatementBuilder, TableForeignKey};
/// Drop a foreign key constraint for an existing table
///
/// # Examples
///
/// ```
/// use sea_query::{tests_cfg::*, *};
///
/// let foreign_key = ForeignKey::drop()
/// .name("FK_character_font")
/// .table(Char::Table)
/// .to_owned();
///
/// assert_eq!(
/// foreign_key.to_string(MysqlQueryBuilder),
/// r#"ALTER TABLE `character` DROP FOREIGN KEY `FK_character_font`"#
/// );
/// assert_eq!(
/// foreign_key.to_string(PostgresQueryBuilder),
/// r#"ALTER TABLE "character" DROP CONSTRAINT "FK_character_font""#
/// );
/// // Sqlite does not support modification of foreign key constraints to existing tables
/// ```
#[derive(Default, Debug, Clone)]
pub struct ForeignKeyDropStatement {
pub(crate) foreign_key: TableForeignKey,
pub(crate) table: Option<TableRef>,
}
impl ForeignKeyDropStatement {
/// Construct a new [`ForeignKeyDropStatement`]
pub fn new() -> Self {
Self::default()
}
/// Set foreign key name
pub fn name<T>(&mut self, name: T) -> &mut Self
where
T: Into<String>,
{
self.foreign_key.name(name);
self
}
/// Set key table and referencing table
pub fn table<T>(&mut self, table: T) -> &mut Self
where
T: IntoTableRef,
{
self.table = Some(table.into_table_ref());
self
}
}
#[inherent]
impl SchemaStatementBuilder for ForeignKeyDropStatement {
pub fn build<T: SchemaBuilder>(&self, schema_builder: T) -> String {
let mut sql = String::with_capacity(256);
schema_builder.prepare_foreign_key_drop_statement(self, &mut sql);
sql
}
pub fn build_any(&self, schema_builder: &dyn SchemaBuilder) -> String {
let mut sql = String::with_capacity(256);
schema_builder.prepare_foreign_key_drop_statement(self, &mut sql);
sql
}
pub fn to_string<T: SchemaBuilder>(&self, schema_builder: T) -> String;
}