Skip to content

Releases: SeaQL/sea-orm

0.6.0

06 Feb 16:58
Compare
Choose a tag to compare

https://www.sea-ql.org/blog/2022-02-07-whats-new-in-0.6.0/

New Features

Enhancements

Bug Fixes

  • CLI allow generate entity with url without password by @billy1624 in #436
  • Support up to 6-ary composite primary key by @billy1624 in #423
  • Fix FromQueryResult when Result is redefined by @tasn in #495
  • Remove r# prefix when deriving FromQueryResult by @smrtrfszm in #494

Breaking Changes

  • Name conflict of foreign key constraints when two entities have more than one foreign keys by @billy1624 in #417

Fixed Issues

  • Is it possible to have 4 values Composite Key? #352
  • Support DateTime<Utc> & DateTime<Local> #381
  • Codegen column_name proc_macro attribute if column name isn't in snake case #395
  • Model with Generics #402
  • Foreign key constraint collision when multiple keys exist between the same two tables #405
  • sea-orm-cli passwordless database user causes "No password was found in the database url" error #435
  • Testing joins with MockDatabase #447
  • Surface max_lifetime connection option #475

New Contributors

Full Changelog: 0.5.0...0.6.0

0.5.0

06 Feb 16:55
Compare
Choose a tag to compare

https://www.sea-ql.org/blog/2022-01-01-whats-new-in-0.5.0/

Fixed Issues

  • Why insert, update, etc return a ActiveModel instead of Model? #289
  • Rework ActiveValue #321
  • Some missing ActiveEnum utilities #338

Merged PRs

Breaking Changes

  • ActiveModel::insert and ActiveModel::update return Model instead of ActiveModel
  • Method ActiveModelBehavior::after_save takes Model as input instead of ActiveModel
  • Rename method sea_orm::unchanged_active_value_not_intended_for_public_use to sea_orm::Unchanged
  • Rename method ActiveValue::unset to ActiveValue::not_set
  • Rename method ActiveValue::is_unset to ActiveValue::is_not_set
  • PartialEq of ActiveValue will also check the equality of state instead of just checking the equality of value

New Contributors

  • @ttys3 made their first contribution in #383
  • @Gabriel-Paulucci made their first contribution in #384

Full Changelog: 0.4.2...0.5.0

0.4.2

12 Dec 15:01
Compare
Choose a tag to compare

Fixed Issues

  • Delete::many() doesn't work when schema_name is defined #362
  • find_with_related panic #374
  • How to define rust type of TIMESTAMP? #344
  • Add Table on the generated Column enum #356

Merged PRs

New Contributors

Full Changelog: 0.4.1...0.4.2

0.4.1

04 Dec 16:19
Compare
Choose a tag to compare

Fixed Issues

  • Is it possible to have 4 values Composite Key? #352
  • [sea-orm-cli] Better handling of relation generations #239

Merged PRs

  • Add TryFromU64 trait for DateTime<FixedOffset>. by @kev0960 in #331
  • add offset and limit by @lz1998 in #351
  • For some reason the axum_example fail to compile by @billy1624 in #355
  • Support Up to 6 Values Composite Primary Key by @billy1624 in #353
  • Codegen Handle Self Referencing & Multiple Relations to the Same Related Entity by @billy1624 in #347

New Contributors

Full Changelog: 0.4.0...0.4.1

0.4.0

19 Nov 15:19
Compare
Choose a tag to compare

https://www.sea-ql.org/blog/2021-11-19-whats-new-in-0.4.0/

Fixed Issues

  • Disable SQLx query logging #290
  • Code generated by sea-orm-cli cannot pass clippy #296
  • Should return detailed error message for connection failure #310
  • DateTimeWithTimeZone does not implement Serialize and Deserialize #319
  • Support returning clause to avoid database hits #183

Merged PRs

Breaking Changes

  • Refactor paginate() & count() utilities into PaginatorTrait. You can use the paginator as usual but you might need to import PaginatorTrait manually when upgrading from previous version.
    use futures::TryStreamExt;
    use sea_orm::{entity::*, query::*, tests_cfg::cake};
    
    let mut cake_stream = cake::Entity::find()
        .order_by_asc(cake::Column::Id)
        .paginate(db, 50)
        .into_stream();
    
    while let Some(cakes) = cake_stream.try_next().await? {
        // Do something on cakes: Vec<cake::Model>
    }
  • The helper struct Schema converting EntityTrait into different sea-query statement now has to be initialized with DbBackend.
    use sea_orm::{tests_cfg::*, DbBackend, Schema};
    use sea_orm::sea_query::TableCreateStatement;
    
    // 0.3.x
    let _: TableCreateStatement = Schema::create_table_from_entity(cake::Entity);
    
    // 0.4.x
    let schema: Schema = Schema::new(DbBackend::MySql);
    let _: TableCreateStatement = schema.create_table_from_entity(cake::Entity);
  • When performing insert or update operation on ActiveModel against PostgreSQL, RETURNING clause will be used to perform select in a single SQL statement.
    // For PostgreSQL
    cake::ActiveModel {
        name: Set("Apple Pie".to_owned()),
        ..Default::default()
    }
    .insert(&postgres_db)
    .await?;
    
    assert_eq!(
        postgres_db.into_transaction_log(),
        vec![Transaction::from_sql_and_values(
            DbBackend::Postgres,
            r#"INSERT INTO "cake" ("name") VALUES ($1) RETURNING "id", "name""#,
            vec!["Apple Pie".into()]
        )]);
    // For MySQL & SQLite
    cake::ActiveModel {
        name: Set("Apple Pie".to_owned()),
        ..Default::default()
    }
    .insert(&other_db)
    .await?;
    
    assert_eq!(
        other_db.into_transaction_log(),
        vec![
            Transaction::from_sql_and_values(
                DbBackend::MySql,
                r#"INSERT INTO `cake` (`name`) VALUES (?)"#,
                vec!["Apple Pie".into()]
            ),
            Transaction::from_sql_and_values(
                DbBackend::MySql,
                r#"SELECT `cake`.`id`, `cake`.`name` FROM `cake` WHERE `cake`.`id` = ? LIMIT ?"#,
                vec![15.into(), 1u64.into()]
            )]);

New Contributors

Full Changelog: 0.3.2...0.4.0

0.3.2

02 Nov 17:42
Compare
Choose a tag to compare

Fixed Issues

  • Support for BYTEA Postgres primary keys #286

Merged PRs

New Contributors

Full Changelog: 0.3.1...0.3.2

0.3.1

23 Oct 08:11
Compare
Choose a tag to compare

Fixed Issues

  • Align case trasforms across derive macros #262
  • Added is_null and is_not_null to ColumnTrait #267

Merged PRs

New Contributors

Full Changelog: 0.3.0...0.3.1

0.3.0

15 Oct 18:11
Compare
Choose a tag to compare

https://www.sea-ql.org/blog/2021-10-15-whats-new-in-0.3.0/

  • Built-in Rocket support
  • ConnectOptions
let mut opt = ConnectOptions::new("protocol://username:password@host/database".to_owned());
opt.max_connections(100)
    .min_connections(5)
    .connect_timeout(Duration::from_secs(8))
    .idle_timeout(Duration::from_secs(8));
let db = Database::connect(opt).await?;
  • [#211] Throw error if none of the db rows are affected
assert_eq!(
    Update::one(cake::ActiveModel {
        name: Set("Cheese Cake".to_owned()),
        ..model.into_active_model()
    })
    .exec(&db)
    .await,
    Err(DbErr::RecordNotFound(
        "None of the database rows are affected".to_owned()
    ))
);

assert_eq!(
    Update::many(cake::Entity)
        .col_expr(cake::Column::Name, Expr::value("Cheese Cake".to_owned()))
        .filter(cake::Column::Id.eq(2))
        .exec(&db)
        .await,
    Ok(UpdateResult { rows_affected: 0 })
);
  • [#223] ActiveValue::take() & ActiveValue::into_value() without unwrap()
  • [#205] Drop Default trait bound of PrimaryKeyTrait::ValueType
  • [#222] Transaction & streaming
  • [#210] Update ActiveModelBehavior API
  • [#240] Add derive DeriveIntoActiveModel and IntoActiveValue trait
  • [#237] Introduce optional serde support for model code generation
  • [#246] Add #[automatically_derived] to all derived implementations

0.2.6

09 Oct 15:20
Compare
Choose a tag to compare
  • [#224] [sea-orm-cli] Date & Time column type mapping
  • Escape rust keywords with r# raw identifier

0.2.5

06 Oct 10:56
Compare
Choose a tag to compare
  • [#227] Resolve "Inserting actual none value of Option results in panic"
  • [#219] [sea-orm-cli] Add --tables option
  • [#189] Add debug_query and debug_query_stmt macro