You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
There seem to be some changes that are breaking changes but aren't mentioned in the Changelog, which tripped me up during an upgrade. It would be helpful to expand the information in the ChangeLog for others.
The requirement to always define an ActiveModel for a table. In v0.12 I did not implement ActiveModel for some tables because they are read-only, managed directly by some database triggers. In this instance SeaORM defines the schema and I wanted a compile error should somebody try to write code to update the rows.
error[E0412]: cannot find type `ActiveModel` in this scope
--> table.rs:5:39
|
5 | #[derive(Copy,Clone,Default,Debug,DeriveEntity)]
| ^^^^^^^^^^^^
|
= note: this error originates in the derive macro `DeriveEntity` (in Nightly builds, run with -Z macro-backtrace for more info)
help: consider importing one of these items
Yes, I think I changed the derive macro in #2186 I know that is breaking, and it should only impact relatively few users. we've never thought about the "entity without active model = read only" use case. and may be we can work something out to make it a feature.
I am not sure if it will work, can a trait associated constant, say READ_ONLY = true in EntityTrait, trigger a compile-time error with a const fn shall we attempt to call save?
regarding binary, BlobSize is really a MySQL thing, it doesn't exist in Postgres, usually VarBinary is used.
Upgrading from SeaORM 0.12 to 1.1
There seem to be some changes that are breaking changes but aren't mentioned in the Changelog, which tripped me up during an upgrade. It would be helpful to expand the information in the ChangeLog for others.
ActiveModel
for a table. In v0.12 I did not implementActiveModel
for some tables because they are read-only, managed directly by some database triggers. In this instance SeaORM defines the schema and I wanted a compile error should somebody try to write code to update the rows.I see it's now written in the doc here that it should always be defined: https://www.sea-ql.org/SeaORM/docs/generate-entity/entity-structure/
ColumnType::String
definitions seem to have changed, wrapped by StringLen.ColumnType::String(Some(32)).def()
use sea_orm::sea_query::BlobSize
has been Dropped, but no indication of what it should have been replaced with.I guess that
ColumnType::Binary(BlobSize::Blob(None)).def()
should beColumnType::Binary(0).def()
ColumnType defines:
On PostgreSQL should I now be using
ColumnType::VarBinary(StringLen::None)
orColumnType::Binary(0).def()
or does it matter?The text was updated successfully, but these errors were encountered: