From 0c39e77c7ebc0e9ae5b314f3eb5f850393d94931 Mon Sep 17 00:00:00 2001 From: Billy Chan Date: Wed, 19 Jun 2024 15:56:48 +0800 Subject: [PATCH] Migration schema nullable column set `null` explicitly (#2255) * Migration schema set null explicitly * Migration test use schema helper --- sea-orm-migration/src/schema.rs | 183 ++++++++++-------- .../m20220118_000001_create_cake_table.rs | 12 +- .../m20220118_000002_create_fruit_table.rs | 14 +- 3 files changed, 112 insertions(+), 97 deletions(-) diff --git a/sea-orm-migration/src/schema.rs b/sea-orm-migration/src/schema.rs index 4c1d690ab..47ecd05d6 100644 --- a/sea-orm-migration/src/schema.rs +++ b/sea-orm-migration/src/schema.rs @@ -74,11 +74,11 @@ pub fn pk_auto(name: T) -> ColumnDef { } pub fn char_len(col: T, length: u32) -> ColumnDef { - char_len_null(col, length).not_null().take() + ColumnDef::new(col).char_len(length).not_null().take() } pub fn char_len_null(col: T, length: u32) -> ColumnDef { - ColumnDef::new(col).char_len(length).take() + ColumnDef::new(col).char_len(length).null().take() } pub fn char_len_uniq(col: T, length: u32) -> ColumnDef { @@ -86,11 +86,11 @@ pub fn char_len_uniq(col: T, length: u32) -> ColumnDef { } pub fn char(col: T) -> ColumnDef { - char_null(col).not_null().take() + ColumnDef::new(col).char().not_null().take() } pub fn char_null(col: T) -> ColumnDef { - ColumnDef::new(col).char().take() + ColumnDef::new(col).char().null().take() } pub fn char_uniq(col: T) -> ColumnDef { @@ -98,11 +98,11 @@ pub fn char_uniq(col: T) -> ColumnDef { } pub fn string_len(col: T, length: u32) -> ColumnDef { - string_len_null(col, length).not_null().take() + ColumnDef::new(col).string_len(length).not_null().take() } pub fn string_len_null(col: T, length: u32) -> ColumnDef { - ColumnDef::new(col).string_len(length).take() + ColumnDef::new(col).string_len(length).null().take() } pub fn string_len_uniq(col: T, length: u32) -> ColumnDef { @@ -110,11 +110,11 @@ pub fn string_len_uniq(col: T, length: u32) -> ColumnDef { } pub fn string(col: T) -> ColumnDef { - string_null(col).not_null().take() + ColumnDef::new(col).string().not_null().take() } pub fn string_null(col: T) -> ColumnDef { - ColumnDef::new(col).string().take() + ColumnDef::new(col).string().null().take() } pub fn string_uniq(col: T) -> ColumnDef { @@ -122,11 +122,11 @@ pub fn string_uniq(col: T) -> ColumnDef { } pub fn text(col: T) -> ColumnDef { - text_null(col).not_null().take() + ColumnDef::new(col).text().not_null().take() } pub fn text_null(col: T) -> ColumnDef { - ColumnDef::new(col).text().take() + ColumnDef::new(col).text().null().take() } pub fn text_uniq(col: T) -> ColumnDef { @@ -134,11 +134,11 @@ pub fn text_uniq(col: T) -> ColumnDef { } pub fn tiny_integer(col: T) -> ColumnDef { - tiny_integer_null(col).not_null().take() + ColumnDef::new(col).tiny_integer().not_null().take() } pub fn tiny_integer_null(col: T) -> ColumnDef { - ColumnDef::new(col).tiny_integer().take() + ColumnDef::new(col).tiny_integer().null().take() } pub fn tiny_integer_uniq(col: T) -> ColumnDef { @@ -146,11 +146,11 @@ pub fn tiny_integer_uniq(col: T) -> ColumnDef { } pub fn small_integer(col: T) -> ColumnDef { - small_integer_null(col).not_null().take() + ColumnDef::new(col).small_integer().not_null().take() } pub fn small_integer_null(col: T) -> ColumnDef { - ColumnDef::new(col).small_integer().take() + ColumnDef::new(col).small_integer().null().take() } pub fn small_integer_uniq(col: T) -> ColumnDef { @@ -158,11 +158,11 @@ pub fn small_integer_uniq(col: T) -> ColumnDef { } pub fn integer(col: T) -> ColumnDef { - integer_null(col).not_null().take() + ColumnDef::new(col).integer().not_null().take() } pub fn integer_null(col: T) -> ColumnDef { - ColumnDef::new(col).integer().take() + ColumnDef::new(col).integer().null().take() } pub fn integer_uniq(col: T) -> ColumnDef { @@ -170,11 +170,11 @@ pub fn integer_uniq(col: T) -> ColumnDef { } pub fn big_integer(col: T) -> ColumnDef { - big_integer_null(col).not_null().take() + ColumnDef::new(col).big_integer().not_null().take() } pub fn big_integer_null(col: T) -> ColumnDef { - ColumnDef::new(col).big_integer().take() + ColumnDef::new(col).big_integer().null().take() } pub fn big_integer_uniq(col: T) -> ColumnDef { @@ -182,11 +182,11 @@ pub fn big_integer_uniq(col: T) -> ColumnDef { } pub fn tiny_unsigned(col: T) -> ColumnDef { - tiny_unsigned_null(col).not_null().take() + ColumnDef::new(col).tiny_unsigned().not_null().take() } pub fn tiny_unsigned_null(col: T) -> ColumnDef { - ColumnDef::new(col).tiny_unsigned().take() + ColumnDef::new(col).tiny_unsigned().null().take() } pub fn tiny_unsigned_uniq(col: T) -> ColumnDef { @@ -194,11 +194,11 @@ pub fn tiny_unsigned_uniq(col: T) -> ColumnDef { } pub fn small_unsigned(col: T) -> ColumnDef { - small_unsigned_null(col).not_null().take() + ColumnDef::new(col).small_unsigned().not_null().take() } pub fn small_unsigned_null(col: T) -> ColumnDef { - ColumnDef::new(col).small_unsigned().take() + ColumnDef::new(col).small_unsigned().null().take() } pub fn small_unsigned_uniq(col: T) -> ColumnDef { @@ -206,11 +206,11 @@ pub fn small_unsigned_uniq(col: T) -> ColumnDef { } pub fn unsigned(col: T) -> ColumnDef { - unsigned_null(col).not_null().take() + ColumnDef::new(col).unsigned().not_null().take() } pub fn unsigned_null(col: T) -> ColumnDef { - ColumnDef::new(col).unsigned().take() + ColumnDef::new(col).unsigned().null().take() } pub fn unsigned_uniq(col: T) -> ColumnDef { @@ -218,11 +218,11 @@ pub fn unsigned_uniq(col: T) -> ColumnDef { } pub fn big_unsigned(col: T) -> ColumnDef { - big_unsigned_null(col).not_null().take() + ColumnDef::new(col).big_unsigned().not_null().take() } pub fn big_unsigned_null(col: T) -> ColumnDef { - ColumnDef::new(col).big_unsigned().take() + ColumnDef::new(col).big_unsigned().null().take() } pub fn big_unsigned_uniq(col: T) -> ColumnDef { @@ -230,11 +230,11 @@ pub fn big_unsigned_uniq(col: T) -> ColumnDef { } pub fn float(col: T) -> ColumnDef { - float_null(col).not_null().take() + ColumnDef::new(col).float().not_null().take() } pub fn float_null(col: T) -> ColumnDef { - ColumnDef::new(col).float().take() + ColumnDef::new(col).float().null().take() } pub fn float_uniq(col: T) -> ColumnDef { @@ -242,11 +242,11 @@ pub fn float_uniq(col: T) -> ColumnDef { } pub fn double(col: T) -> ColumnDef { - double_null(col).not_null().take() + ColumnDef::new(col).double().not_null().take() } pub fn double_null(col: T) -> ColumnDef { - ColumnDef::new(col).double().take() + ColumnDef::new(col).double().null().take() } pub fn double_uniq(col: T) -> ColumnDef { @@ -254,11 +254,17 @@ pub fn double_uniq(col: T) -> ColumnDef { } pub fn decimal_len(col: T, precision: u32, scale: u32) -> ColumnDef { - decimal_len_null(col, precision, scale).not_null().take() + ColumnDef::new(col) + .decimal_len(precision, scale) + .not_null() + .take() } pub fn decimal_len_null(col: T, precision: u32, scale: u32) -> ColumnDef { - ColumnDef::new(col).decimal_len(precision, scale).take() + ColumnDef::new(col) + .decimal_len(precision, scale) + .null() + .take() } pub fn decimal_len_uniq(col: T, precision: u32, scale: u32) -> ColumnDef { @@ -266,11 +272,11 @@ pub fn decimal_len_uniq(col: T, precision: u32, scale: u32) -> Colu } pub fn decimal(col: T) -> ColumnDef { - decimal_null(col).not_null().take() + ColumnDef::new(col).decimal().not_null().take() } pub fn decimal_null(col: T) -> ColumnDef { - ColumnDef::new(col).decimal().take() + ColumnDef::new(col).decimal().null().take() } pub fn decimal_uniq(col: T) -> ColumnDef { @@ -278,11 +284,11 @@ pub fn decimal_uniq(col: T) -> ColumnDef { } pub fn date_time(col: T) -> ColumnDef { - date_time_null(col).not_null().take() + ColumnDef::new(col).date_time().not_null().take() } pub fn date_time_null(col: T) -> ColumnDef { - ColumnDef::new(col).date_time().take() + ColumnDef::new(col).date_time().null().take() } pub fn date_time_uniq(col: T) -> ColumnDef { @@ -294,7 +300,10 @@ pub fn interval( fields: Option, precision: Option, ) -> ColumnDef { - interval_null(col, fields, precision).not_null().take() + ColumnDef::new(col) + .interval(fields, precision) + .not_null() + .take() } pub fn interval_null( @@ -302,7 +311,10 @@ pub fn interval_null( fields: Option, precision: Option, ) -> ColumnDef { - ColumnDef::new(col).interval(fields, precision).take() + ColumnDef::new(col) + .interval(fields, precision) + .null() + .take() } pub fn interval_uniq( @@ -314,11 +326,11 @@ pub fn interval_uniq( } pub fn timestamp(col: T) -> ColumnDef { - timestamp_null(col).not_null().take() + ColumnDef::new(col).timestamp().not_null().take() } pub fn timestamp_null(col: T) -> ColumnDef { - ColumnDef::new(col).timestamp().take() + ColumnDef::new(col).timestamp().null().take() } pub fn timestamp_uniq(col: T) -> ColumnDef { @@ -326,11 +338,14 @@ pub fn timestamp_uniq(col: T) -> ColumnDef { } pub fn timestamp_with_time_zone(col: T) -> ColumnDef { - timestamp_with_time_zone_null(col).not_null().take() + ColumnDef::new(col) + .timestamp_with_time_zone() + .not_null() + .take() } pub fn timestamp_with_time_zone_null(col: T) -> ColumnDef { - ColumnDef::new(col).timestamp_with_time_zone().take() + ColumnDef::new(col).timestamp_with_time_zone().null().take() } pub fn timestamp_with_time_zone_uniq(col: T) -> ColumnDef { @@ -338,11 +353,11 @@ pub fn timestamp_with_time_zone_uniq(col: T) -> ColumnDef { } pub fn time(col: T) -> ColumnDef { - time_null(col).not_null().take() + ColumnDef::new(col).time().not_null().take() } pub fn time_null(col: T) -> ColumnDef { - ColumnDef::new(col).time().take() + ColumnDef::new(col).time().null().take() } pub fn time_uniq(col: T) -> ColumnDef { @@ -350,11 +365,11 @@ pub fn time_uniq(col: T) -> ColumnDef { } pub fn date(col: T) -> ColumnDef { - date_null(col).not_null().take() + ColumnDef::new(col).date().not_null().take() } pub fn date_null(col: T) -> ColumnDef { - ColumnDef::new(col).date().take() + ColumnDef::new(col).date().null().take() } pub fn date_uniq(col: T) -> ColumnDef { @@ -362,11 +377,11 @@ pub fn date_uniq(col: T) -> ColumnDef { } pub fn year(col: T) -> ColumnDef { - year_null(col).not_null().take() + ColumnDef::new(col).year().not_null().take() } pub fn year_null(col: T) -> ColumnDef { - ColumnDef::new(col).year().take() + ColumnDef::new(col).year().null().take() } pub fn year_uniq(col: T) -> ColumnDef { @@ -374,11 +389,11 @@ pub fn year_uniq(col: T) -> ColumnDef { } pub fn binary_len(col: T, length: u32) -> ColumnDef { - binary_len_null(col, length).not_null().take() + ColumnDef::new(col).binary_len(length).not_null().take() } pub fn binary_len_null(col: T, length: u32) -> ColumnDef { - ColumnDef::new(col).binary_len(length).take() + ColumnDef::new(col).binary_len(length).null().take() } pub fn binary_len_uniq(col: T, length: u32) -> ColumnDef { @@ -386,11 +401,11 @@ pub fn binary_len_uniq(col: T, length: u32) -> ColumnDef { } pub fn binary(col: T) -> ColumnDef { - binary_null(col).not_null().take() + ColumnDef::new(col).binary().not_null().take() } pub fn binary_null(col: T) -> ColumnDef { - ColumnDef::new(col).binary().take() + ColumnDef::new(col).binary().null().take() } pub fn binary_uniq(col: T) -> ColumnDef { @@ -398,11 +413,11 @@ pub fn binary_uniq(col: T) -> ColumnDef { } pub fn var_binary(col: T, length: u32) -> ColumnDef { - var_binary_null(col, length).not_null().take() + ColumnDef::new(col).var_binary(length).not_null().take() } pub fn var_binary_null(col: T, length: u32) -> ColumnDef { - ColumnDef::new(col).var_binary(length).take() + ColumnDef::new(col).var_binary(length).null().take() } pub fn var_binary_uniq(col: T, length: u32) -> ColumnDef { @@ -410,11 +425,11 @@ pub fn var_binary_uniq(col: T, length: u32) -> ColumnDef { } pub fn bit(col: T, length: Option) -> ColumnDef { - bit_null(col, length).not_null().take() + ColumnDef::new(col).bit(length).not_null().take() } pub fn bit_null(col: T, length: Option) -> ColumnDef { - ColumnDef::new(col).bit(length).take() + ColumnDef::new(col).bit(length).null().take() } pub fn bit_uniq(col: T, length: Option) -> ColumnDef { @@ -422,11 +437,11 @@ pub fn bit_uniq(col: T, length: Option) -> ColumnDef { } pub fn varbit(col: T, length: u32) -> ColumnDef { - varbit_null(col, length).not_null().take() + ColumnDef::new(col).varbit(length).not_null().take() } pub fn varbit_null(col: T, length: u32) -> ColumnDef { - ColumnDef::new(col).varbit(length).take() + ColumnDef::new(col).varbit(length).null().take() } pub fn varbit_uniq(col: T, length: u32) -> ColumnDef { @@ -434,11 +449,11 @@ pub fn varbit_uniq(col: T, length: u32) -> ColumnDef { } pub fn blob(col: T) -> ColumnDef { - blob_null(col).not_null().take() + ColumnDef::new(col).blob().not_null().take() } pub fn blob_null(col: T) -> ColumnDef { - ColumnDef::new(col).blob().take() + ColumnDef::new(col).blob().null().take() } pub fn blob_uniq(col: T) -> ColumnDef { @@ -446,11 +461,11 @@ pub fn blob_uniq(col: T) -> ColumnDef { } pub fn boolean(col: T) -> ColumnDef { - boolean_null(col).not_null().take() + ColumnDef::new(col).boolean().not_null().take() } pub fn boolean_null(col: T) -> ColumnDef { - ColumnDef::new(col).boolean().take() + ColumnDef::new(col).boolean().null().take() } pub fn boolean_uniq(col: T) -> ColumnDef { @@ -458,11 +473,17 @@ pub fn boolean_uniq(col: T) -> ColumnDef { } pub fn money_len(col: T, precision: u32, scale: u32) -> ColumnDef { - money_len_null(col, precision, scale).not_null().take() + ColumnDef::new(col) + .money_len(precision, scale) + .not_null() + .take() } pub fn money_len_null(col: T, precision: u32, scale: u32) -> ColumnDef { - ColumnDef::new(col).money_len(precision, scale).take() + ColumnDef::new(col) + .money_len(precision, scale) + .null() + .take() } pub fn money_len_uniq(col: T, precision: u32, scale: u32) -> ColumnDef { @@ -470,11 +491,11 @@ pub fn money_len_uniq(col: T, precision: u32, scale: u32) -> Column } pub fn money(col: T) -> ColumnDef { - money_null(col).not_null().take() + ColumnDef::new(col).money().not_null().take() } pub fn money_null(col: T) -> ColumnDef { - ColumnDef::new(col).money().take() + ColumnDef::new(col).money().null().take() } pub fn money_uniq(col: T) -> ColumnDef { @@ -482,11 +503,11 @@ pub fn money_uniq(col: T) -> ColumnDef { } pub fn json(col: T) -> ColumnDef { - json_null(col).not_null().take() + ColumnDef::new(col).json().not_null().take() } pub fn json_null(col: T) -> ColumnDef { - ColumnDef::new(col).json().take() + ColumnDef::new(col).json().null().take() } pub fn json_uniq(col: T) -> ColumnDef { @@ -494,11 +515,11 @@ pub fn json_uniq(col: T) -> ColumnDef { } pub fn json_binary(col: T) -> ColumnDef { - json_binary_null(col).not_null().take() + ColumnDef::new(col).json_binary().not_null().take() } pub fn json_binary_null(col: T) -> ColumnDef { - ColumnDef::new(col).json_binary().take() + ColumnDef::new(col).json_binary().null().take() } pub fn json_binary_uniq(col: T) -> ColumnDef { @@ -506,11 +527,11 @@ pub fn json_binary_uniq(col: T) -> ColumnDef { } pub fn uuid(col: T) -> ColumnDef { - uuid_null(col).not_null().take() + ColumnDef::new(col).uuid().not_null().take() } pub fn uuid_null(col: T) -> ColumnDef { - ColumnDef::new(col).uuid().take() + ColumnDef::new(col).uuid().null().take() } pub fn uuid_uniq(col: T) -> ColumnDef { @@ -518,11 +539,11 @@ pub fn uuid_uniq(col: T) -> ColumnDef { } pub fn custom(col: T, name: T) -> ColumnDef { - custom_null(col, name).not_null().take() + ColumnDef::new(col).custom(name).not_null().take() } pub fn custom_null(col: T, name: T) -> ColumnDef { - ColumnDef::new(col).custom(name).take() + ColumnDef::new(col).custom(name).null().take() } pub fn enumeration(col: T, name: N, variants: V) -> ColumnDef @@ -532,7 +553,10 @@ where S: IntoIden, V: IntoIterator, { - enumeration_null(col, name, variants).not_null().take() + ColumnDef::new(col) + .enumeration(name, variants) + .not_null() + .take() } pub fn enumeration_null(col: T, name: N, variants: V) -> ColumnDef @@ -542,7 +566,10 @@ where S: IntoIden, V: IntoIterator, { - ColumnDef::new(col).enumeration(name, variants).take() + ColumnDef::new(col) + .enumeration(name, variants) + .null() + .take() } pub fn enumeration_uniq(col: T, name: N, variants: V) -> ColumnDef @@ -556,11 +583,11 @@ where } pub fn array(col: T, elem_type: ColumnType) -> ColumnDef { - array_null(col, elem_type).not_null().take() + ColumnDef::new(col).array(elem_type).not_null().take() } pub fn array_null(col: T, elem_type: ColumnType) -> ColumnDef { - ColumnDef::new(col).array(elem_type).take() + ColumnDef::new(col).array(elem_type).null().take() } pub fn array_uniq(col: T, elem_type: ColumnType) -> ColumnDef { diff --git a/sea-orm-migration/tests/common/migration/m20220118_000001_create_cake_table.rs b/sea-orm-migration/tests/common/migration/m20220118_000001_create_cake_table.rs index ea733f8c2..4aab3645f 100644 --- a/sea-orm-migration/tests/common/migration/m20220118_000001_create_cake_table.rs +++ b/sea-orm-migration/tests/common/migration/m20220118_000001_create_cake_table.rs @@ -1,4 +1,4 @@ -use sea_orm_migration::prelude::*; +use sea_orm_migration::{prelude::*, schema::*}; #[derive(DeriveMigrationName)] pub struct Migration; @@ -10,14 +10,8 @@ impl MigrationTrait for Migration { .create_table( Table::create() .table(Cake::Table) - .col( - ColumnDef::new(Cake::Id) - .integer() - .not_null() - .auto_increment() - .primary_key(), - ) - .col(ColumnDef::new(Cake::Name).string().not_null()) + .col(pk_auto(Cake::Id)) + .col(string(Cake::Name)) .to_owned(), ) .await?; diff --git a/sea-orm-migration/tests/common/migration/m20220118_000002_create_fruit_table.rs b/sea-orm-migration/tests/common/migration/m20220118_000002_create_fruit_table.rs index 4b9ceb458..39009cc8a 100644 --- a/sea-orm-migration/tests/common/migration/m20220118_000002_create_fruit_table.rs +++ b/sea-orm-migration/tests/common/migration/m20220118_000002_create_fruit_table.rs @@ -1,6 +1,6 @@ use super::m20220118_000001_create_cake_table::Cake; -use sea_orm_migration::prelude::*; use sea_orm_migration::sea_orm::DbBackend; +use sea_orm_migration::{prelude::*, schema::*}; #[derive(DeriveMigrationName)] pub struct Migration; @@ -12,15 +12,9 @@ impl MigrationTrait for Migration { .create_table( Table::create() .table(Fruit::Table) - .col( - ColumnDef::new(Fruit::Id) - .integer() - .not_null() - .auto_increment() - .primary_key(), - ) - .col(ColumnDef::new(Fruit::Name).string().not_null()) - .col(ColumnDef::new(Fruit::CakeId).integer().not_null()) + .col(pk_auto(Fruit::Id)) + .col(string(Fruit::Name)) + .col(integer(Fruit::CakeId)) .foreign_key( ForeignKey::create() .name("fk-fruit-cake_id")