Ormar

Latest version: v0.20.1

Safety actively analyzes 682229 Python packages for vulnerabilities to keep your Python projects secure.

Scan your dependencies

Page 1 of 14

0.20.1

✨ Breaking changes

* Note that this is the first non-beta release of ormar with support for Pydantic v2. Check release notes for 0.20.0 and https://collerek.github.io/ormar/0.20.0b1/migration/

🐛 Fixes

* Fix merging same target models when using `select_related` with `prefetch_related` [906](https://github.com/collerek/ormar/issues/906)
* Fix saving related with pk only models [812](https://github.com/collerek/ormar/issues/812)
* Fix adding the same relation multiple times corrupting relation cache [1335](https://github.com/collerek/ormar/issues/1335)

✨ Features

* Allow adding indexed on foreign keys by cmflynn [1276](https://github.com/collerek/ormar/pull/1276)

💬 Other
* Some docs fixes by Chaoyingz, thanks!

0.20.0

✨ Breaking changes
* `ormar` Model configuration

Instead of defining a `Meta` class now each of the ormar models require an ormar_config parameter that is an instance of the `OrmarConfig` class.
Note that the attribute must be named `ormar_config` and be an instance of the config class.

python
import databases
import ormar
import sqlalchemy

database = databases.Database("sqlite:///db.sqlite")
metadata = sqlalchemy.MetaData()

ormar < 0.20
class Album(ormar.Model):
class Meta:
database = database
metadata = metadata
tablename = "albums"


id: int = ormar.Integer(primary_key=True)
name: str = ormar.String(max_length=100)
favorite: bool = ormar.Boolean(default=False)

ormar >= 0.20
class AlbumV20(ormar.Model):
ormar_config = ormar.OrmarConfig(
database=database,
metadata=metadata,
tablename="albums_v20"
)

id: int = ormar.Integer(primary_key=True)
name: str = ormar.String(max_length=100)
favorite: bool = ormar.Boolean(default=False)


* `OrmarConfig` api/ parameters

The `ormar_config` expose the same set of settings as `Meta` class used to provide.
That means that you can use any of the following parameters initializing the config:

python
metadata: Optional[sqlalchemy.MetaData]
database: Optional[databases.Database]
engine: Optional[sqlalchemy.engine.Engine]
tablename: Optional[str]
order_by: Optional[List[str]]
abstract: bool
exclude_parent_fields: Optional[List[str]]
queryset_class: Type[QuerySet]
extra: Extra
constraints: Optional[List[ColumnCollectionConstraint]]


* `BaseMeta` equivalent - best practice

Note that to reduce the duplication of code and ease of development it's still recommended to create a base config and provide each of the models with a copy.
OrmarConfig provides a convenient `copy` method for that purpose.

The `copy` method accepts the same parameters as `OrmarConfig` init, so you can overwrite if needed, but by default it will return already existing attributes, except for: `tablename`, `order_by` and `constraints` which by default are cleared.

python hl_lines="5-8 11 20"
import databases
import ormar
import sqlalchemy

base_ormar_config = ormar.OrmarConfig(
database=databases.Database("sqlite:///db.sqlite"),
metadata=sqlalchemy.MetaData()
)

class AlbumV20(ormar.Model):
ormar_config = base_ormar_config.copy(
tablename="albums_v20"
)

id: int = ormar.Integer(primary_key=True)
name: str = ormar.String(max_length=100)


class TrackV20(ormar.Model):
ormar_config = base_ormar_config.copy(
tablename="tracks_v20"
)

id: int = ormar.Integer(primary_key=True)
name: str = ormar.String(max_length=100)


* `choices` Field parameter is no longer supported.

Before version 0.20 you could provide `choices` parameter to any existing ormar Field to limit the accepted values.
This functionality was dropped, and you should use `ormar.Enum` field that was designed for this purpose.
If you want to keep the database field type (i.e. an Integer field) you can always write a custom validator.

python
import databases
import ormar
import sqlalchemy

database = databases.Database("sqlite:///db.sqlite")
metadata = sqlalchemy.MetaData()

ormar < 0.20
class Artist(ormar.Model):
class Meta:
database = database
metadata = metadata


id: int = ormar.Integer(primary_key=True)
name: str = ormar.String(max_length=100)
country: str = ormar.String(default=False, max_length=50, choices=["UK", "US", "Vietnam", "Colombia"])

ormar >= 0.20
from enum import Enum

class Country(str, Enum):
UK = "UK"
US = "US"
VIETNAM = "Vietnam"
COLOMBIA = "Colombia"

class ArtistV20(ormar.Model):
ormar_config = ormar.OrmarConfig(
database=database,
metadata=metadata,
tablename="artists_v20"
)

id: int = ormar.Integer(primary_key=True)
name: str = ormar.String(max_length=100)
country: Country = ormar.Enum(enum_class=Country)



* `pydantic_only` Field parameter is no longer supported

`pydantic_only` fields were already deprecated and are removed in v 0.20. Ormar allows defining pydantic fields as in ordinary pydantic model.

python
import databases
import ormar
import sqlalchemy

database = databases.Database("sqlite:///db.sqlite")
metadata = sqlalchemy.MetaData()

ormar < 0.20
class Dish(ormar.Model):
class Meta:
database = database
metadata = metadata
tablename = "dishes"


id: int = ormar.Integer(primary_key=True)
name: str = ormar.String(max_length=100)
cook: str = ormar.String(max_length=40, pydantic_only=True, default="sam")

ormar >= 0.20
class DishV20(ormar.Model):
ormar_config = ormar.OrmarConfig(
database=database,
metadata=metadata,
tablename="dishes_v20"
)

id: int = ormar.Integer(primary_key=True)
name: str = ormar.String(max_length=100)
cook: str = "sam" this is normal pydantic field


* `property_field` decorator is no longer supported

`property_field` decorator was used to provide a way to pass calculated fields that were included in dictionary/ serialized json representation of the model.
Version 2.X of pydantic introduced such a possibility, so you should now switch to the one native to the pydantic.

python
import databases
import ormar
import sqlalchemy
import pydantic

database = databases.Database("sqlite:///db.sqlite")
metadata = sqlalchemy.MetaData()

ormar < 0.20
class Employee(ormar.Model):
class Meta:
database = database
metadata = metadata


id: int = ormar.Integer(primary_key=True)
first_name: str = ormar.String(max_length=100)
last_name: str = ormar.String(max_length=100)

ormar.property_field()
def full_name(self) -> str:
return f"{self.first_name} {self.last_name}"

ormar >= 0.20
class EmployeeV20(ormar.Model):
ormar_config = ormar.OrmarConfig(
database=database,
metadata=metadata,
)

id: int = ormar.Integer(primary_key=True)
first_name: str = ormar.String(max_length=100)
last_name: str = ormar.String(max_length=100)

pydantic.computed_field()
def full_name(self) -> str:
return f"{self.first_name} {self.last_name}"


* Deprecated methods

All methods listed below are deprecated and will be removed in version 0.30 of `ormar`.

* `dict()` becomes the `model_dump()`

python
import databases
import ormar
import sqlalchemy

database = databases.Database("sqlite:///db.sqlite")
metadata = sqlalchemy.MetaData()

class Album(ormar.Model):
ormar_config = ormar.OrmarConfig(
database=database,
metadata=metadata,
tablename="albums"
)

id: int = ormar.Integer(primary_key=True)
name: str = ormar.String(max_length=100)
favorite: bool = ormar.Boolean(default=False)

album = Album(name="Dark Side of the Moon")

ormar < 0.20
album_dict = album.dict()

ormar >= 0.20
new_album_dict = album.model_dump()


Note that parameters remain the same i.e. `include`, `exclude` etc.

* `json()` becomes the `model_dump_json()`

python
import databases
import ormar
import sqlalchemy

database = databases.Database("sqlite:///db.sqlite")
metadata = sqlalchemy.MetaData()

class Album(ormar.Model):
ormar_config = ormar.OrmarConfig(
database=database,
metadata=metadata,
tablename="albums"
)

id: int = ormar.Integer(primary_key=True)
name: str = ormar.String(max_length=100)
favorite: bool = ormar.Boolean(default=False)

album = Album(name="Dark Side of the Moon")

ormar < 0.20
album_json= album.json()

ormar >= 0.20
new_album_dict = album.model_dump_json()


Note that parameters remain the same i.e. `include`, `exclude` etc.

* `construct()` becomes the `model_construct()`

python
import databases
import ormar
import sqlalchemy

database = databases.Database("sqlite:///db.sqlite")
metadata = sqlalchemy.MetaData()

class Album(ormar.Model):
ormar_config = ormar.OrmarConfig(
database=database,
metadata=metadata,
tablename="albums"
)

id: int = ormar.Integer(primary_key=True)
name: str = ormar.String(max_length=100)
favorite: bool = ormar.Boolean(default=False)

params = {
"name": "Dark Side of the Moon",
"favorite": True,
}
ormar < 0.20
album = Album.construct(**params)

ormar >= 0.20
album = Album.model_construct(**params)


To read more about construct please refer to `pydantic` documentation.

0.12.2

✨ Features
* Bump support for `FastAPI` up to the newest version (0.97.0) [1110](https://github.com/collerek/ormar/pull/1110)
* Add support and tests for `Python 3.11` [1110](https://github.com/collerek/ormar/pull/1110)

0.12.1

✨ Features
* Massive performance improvements in area of loading the models due to recursive loads and caching of the models and related models. (by erichaydel - thanks!) [853](https://github.com/collerek/ormar/pull/948)

💬 Internals
* Benchmarks for comparing performance effect of implemented changes in regard of trends (again, by erichaydel - thanks!) [853](https://github.com/collerek/ormar/pull/948)

0.12.0

✨ Breaking Changes

* `Queryset.bulk_create` will now raise `ModelListEmptyError` on empty list of models (by ponytailer - thanks!) [853](https://github.com/collerek/ormar/pull/853)

✨ Features
* `Model.upsert()` now handles a flag `__force_save__`: `bool` that allow upserting the models regardless of the fact if they have primary key set or not.
Note that setting this flag will cause two queries for each upserted model -> `get` to check if model exists and later `update/insert` accordingly. [889](https://github.com/collerek/ormar/pull/853)

🐛 Fixes

* Fix for empty relations breaking `construct` method (by Abdeldjalil-H - thanks!) [870](https://github.com/collerek/ormar/issues/870)
* Fix save related not saving models with already set pks (including uuid) [885](https://github.com/collerek/ormar/issues/885)
* Fix for wrong relations exclusions depending on the order of exclusions [779](https://github.com/collerek/ormar/issues/779)
* Fix `property_fields` not being inherited properly [774](https://github.com/collerek/ormar/issues/774)

0.11.3

✨ Features

* Document `onupdate` and `ondelete` referential actions in `ForeignKey` and provide `ReferentialAction` enum to specify the behavior of the relationship (by SepehrBazyar - thanks!) [724](https://github.com/collerek/ormar/issues/724)
* Add `CheckColumn` to supported constraints in models Meta (by SepehrBazyar - thanks!) [729](https://github.com/collerek/ormar/issues/729)

🐛 Fixes

* Fix limiting query result to 0 should return empty list (by SepehrBazyar - thanks!) [766](https://github.com/collerek/ormar/issues/713)

💬 Other

* Add dark mode to docs (by SepehrBazyar - thanks!) [717](https://github.com/collerek/ormar/pull/717)
* Update aiomysql dependency [778](https://github.com/collerek/ormar/issues/778)

Page 1 of 14

© 2024 Safety CLI Cybersecurity Inc. All Rights Reserved.