Bug fixes:
- Fix handling of arrays of enums and multidimensional arrays (:issue:`653`). Thanks :user:`carterjc` for reporting and investigating the fix.
- Fix handling of sqlalchemy.PickleType columns (:issue:`394`) Thanks :user:`Eyon42` for reporting.
Other changes:
- Passing arbitrary keyword arguments to auto_field <marshmallow_sqlalchemy.auto_field>
is no longer supported (:pr:`647`). Use the
metadata
argument to pass metadata to the generated field instead.
# Before
auto_field(description="The name of the artist")
# On marshmallow 3, this raises a warning: "RemovedInMarshmallow4Warning: Passing field metadata as keyword arguments is deprecated."
# On marshmallow 4, this raises an error: "TypeError: Field.__init__() got an unexpected keyword argument 'description'"
# After
auto_field(metadata=dict(description="The name of the artist"))
Features:
- Typing: Add type annotations to fields <marshmallow_sqlalchemy.fields>.
Bug fixes:
- Fix auto-generation of marshmallow.fields.Enum field from sqlalchemy.Enum columns (:issue:`615`). Thanks :user:`joaquimvl` for reporting.
- Fix behavior of
include_fk = False
in options when parent schema setsinclude_fk = True
(:issue:`440`). Thanks :user:`uhnomoli` for reporting. - Fields generated from non-nullable sqlalchemy.orm.relationship
correctly set
required=True
andallow_none=False
(:issue:`336`, :issue:`163`). Thanks :user:`AbdealiLoKo` for reporting.
Other changes:
- Docs: Add more documentation for marshmallow_sqlalchemy.fields.Related (:issue:`162`). Thanks :user:`GabrielC101` for the suggestion.
- Docs: Document methods of SQLAlchemySchema <marshmallow_sqalalchemy.SQLAlchemySchema> and SQLAlchemyAutoSchema <marshmallow_sqalchemy.SQLAlchemyAutoSchema> (:issue:`619`).
- Docs: Various documentation improvements (:pr:`635`, :pr:`636`, :pr:`639`, :pr:`641`, :pr:`642`).
Features:
Other changes:
- Drop support for Python 3.8, which is EOL. Support Python 3.9-3.13.
Bug fixes:
- Fix compatibility with marshmallow 3.24.0 and 4.0.0 (:pr:`628`).
Other changes:
- Test against Python 3.13 (:issue:`629`).
Features:
sqlalchemy.Enum
fields generate a correspondingmarshmallow.fields.Enum
field (:issue:`485`, :issue:`112`). Thanks :user:`panda-byte` for the PR.
Support:
- Drop support for marshmallow<3.18.0.
- Remove
__version__
attribute. Use feature detection orimportlib.metadata.version("marshmallow-sqlalchemy")
instead (:pr:`568`). - Support marshmallow>=3.10.0 (:pr:`566`).
- Passing info={"marshmallow": ...} to SQLAlchemy columns is removed, as it is redundant with
the
auto_field
functionality (:pr:`567`). - Remove
packaging
as a dependency (:pr:`566`). - Support Python 3.12.
Features:
- Use
Session.get()
load instances to improve deserialization performance (:pr:`548`). Thanks :user:`zippolyte` for the PR.
Other changes:
- Drop support for Python 3.7, which is EOL (:pr:`540`).
Features:
- Support SQLAlchemy 2.0 (:pr:`494`). Thanks :user:`dependabot` for the PR.
- Enable (in tests) and fix SQLAlchemy 2.0 compatibility warnings (:pr:`493`).
Bug fixes:
- Use mapper
.attrs
rather than.get_property
and.iterate_properties
to ensureregistry.configure
is called (call removed in SQLAlchemy 2.0.2) (:issue:`487`). Thanks :user:`ddoyon92` for the PR.
Other changes:
- Drop support for SQLAlchemy 1.3, which is EOL (:pr:`493`).
Bug fixes:
- Use .scalar_subquery() for SQLAlchemy>1.4 to suppress a warning (:issue:`459`). Thanks :user:`indiVar0508` for the PR.
Other changes:
- Lock SQLAlchemy<2.0 in setup.py. SQLAlchemy 2.x is not supported (:pr:`486`).
- Test against Python 3.11 (:pr:`486`).
Bug fixes:
- Address
DeprecationWarning
re: usage ofdistutils
(:pr:`435`). Thanks :user:`Tenzer` for the PR.
Features:
- Add support for generating fields from column_property (:issue:`97`). Thanks :user:`mrname` for the PR.
Other changes:
- Drop support for Python 3.6, which is EOL.
- Drop support for SQLAlchemy 1.2, which is EOL.
Features:
- Distribute type information per PEP 561 (:pr:`420`). Thanks :user:`bruceadams` for the PR.
Other changes:
- Test against Python 3.10 (:pr:`421`).
Bug fixes:
- Fix generating fields for
postgreql.ARRAY
columns (:issue:`392`). Thanks :user:`mjpieters` for the catch and patch.
Bug fixes:
- Unwrap proxied columns to handle models for subqueries (:issue:`383`). Thanks :user:`mjpieters` for the catch and patch
- Fix setting
transient
on a per-instance basis when thetransient
Meta option is set (:issue:`388`). Thanks again :user:`mjpieters`.
Other changes:
- Backwards-incompatible: Remove deprecated
ModelSchema
andTableSchema
classes.
- Add
load_instance
as a parameter to SQLAlchemySchema and SQLAlchemyAutoSchema (:pr:`380`). Thanks :user:`mjpieters` for the PR.
- Fix deprecation warnings from marshmallow 3.10 and SQLAlchemy 1.4 (:pr:`369`). Thanks :user:`peterschutt` for the PR.
auto_field
supportsassociation_proxy
fields with local multiplicity (uselist=True
) (:issue:`364`). Thanks :user:`Unix-Code` for the catch and patch.
auto_field
works withassociation_proxy
(:issue:`338`). Thanks :user:`AbdealiJK`.
- Backwards-incompatible: Drop support for marshmallow 2.x, which is now EOL.
- Test against Python 3.9.
Bug fixes:
- Don't add no-op Length validator (:pr:`315`). Thanks :user:`taion` for the PR.
Bug fixes:
- Fix data keys when using
Related
with aColumn
that is named differently from its attribute (:issue:`299`). Thanks :user:`peterschutt` for the catch and patch. - Fix bug that raised an exception when using the ordered = True option on a schema that has an auto_field (:issue:`306`). Thanks :user:`KwonL` for reporting and thanks :user:`peterschutt` for the PR.
Bug fixes:
- Fix
DeprecationWarning
getting raised even when user code does not useTableSchema
orModelSchema
(:issue:`289`). Thanks :user:`5uper5hoot` for reporting.
Bug fixes:
- Avoid error when using
SQLAlchemyAutoSchema
,ModelSchema
, orfields_for_model
with a model that has aSynonymProperty
(:issue:`190`). Thanks :user:`TrilceAC` for reporting. auto_field
andfield_for
work withSynonymProperty
(:pr:`280`).
Other changes:
- Add hook in
ModelConverter
for changing field names based on SQLA columns and properties (:issue:`276`). Thanks :user:`davenquinn` for the suggestion and the PR.
Bug fixes:
- Fix behavior when passing
table
toauto_field
(:pr:`277`).
Features:
- Add
SQLAlchemySchema
andSQLAlchemyAutoSchema
, which have an improved API for generating marshmallow fields and overriding their arguments viaauto_field
(:issue:`240`). Thanks :user:`taion` for the idea and original implementation.
# Before
from marshmallow_sqlalchemy import ModelSchema, field_for
from . import models
class ArtistSchema(ModelSchema):
class Meta:
model = models.Artist
id = field_for(models.Artist, "id", dump_only=True)
created_at = field_for(models.Artist, "created_at", dump_only=True)
# After
from marshmallow_sqlalchemy import SQLAlchemySchema, auto_field
from . import models
class ArtistSchema(SQLAlchemyAutoSchema):
class Meta:
model = models.Artist
id = auto_field(dump_only=True)
created_at = auto_field(dump_only=True)
- Add
load_instance
option to configure deserialization to model instances (:issue:`193`, :issue:`270`). - Add
include_relationships
option to configure generation of marshmallow fields for relationship properties (:issue:`98`). Thanks :user:`dusktreader` for the suggestion.
Deprecations:
ModelSchema
andTableSchema
are deprecated, sinceSQLAlchemyAutoSchema
has equivalent functionality.
# Before
from marshmallow_sqlalchemy import ModelSchema, TableSchema
from . import models
class ArtistSchema(ModelSchema):
class Meta:
model = models.Artist
class AlbumSchema(TableSchema):
class Meta:
table = models.Album.__table__
# After
from marshmallow_sqlalchemy import SQLAlchemyAutoSchema
from . import models
class ArtistSchema(SQLAlchemyAutoSchema):
class Meta:
model = models.Artist
include_relationships = True
load_instance = True
class AlbumSchema(SQLAlchemyAutoSchema):
class Meta:
table = models.Album.__table__
- Passing info={"marshmallow": ...} to SQLAlchemy columns is deprecated, as it is redundant with
the
auto_field
functionality.
Other changes:
- Backwards-incompatible:
fields_for_model
does not include relationships by default. Usefields_for_model(..., include_relationships=True)
to preserve the old behavior.
- Add support for
postgresql.OID
type (:pr:`262`). Thanks :user:`petrus-v` for the PR. - Remove imprecise Python 3 classifier from PyPI metadata (:pr:`255`). Thanks :user:`ecederstrand`.
- Add support for
mysql.DATETIME
andmysql.INTEGER
type (:issue:`204`). - Add support for
postgresql.CIDR
type (:issue:`183`). - Add support for
postgresql.DATE
andpostgresql.TIME
type.
Thanks :user:`evelyn9191` for the PR.
- Drop support for Python 2.7 and 3.5 (:issue:`241`).
- Drop support for marshmallow<2.15.2.
- Only support sqlalchemy>=1.2.0.
Features:
marshmallow_sqlalchemy.fields.Nested
propagates the value oftransient
on the call toload
(:issue:`177`, :issue:`206`). Thanks :user:`leonidumanskiy` for reporting.
Note: This is the last release to support Python 2.7 and 3.5.
Bug fixes:
- Fix error handling when passing an invalid type to
Related
(:issue:`223`). Thanks :user:`heckad` for reporting. - Address
DeprecationWarning
raised when usingRelated
with marshmallow 3 (:pr:`243`).
Bug fixes:
- Add
marshmallow_sqlalchemy.fields.Nested
field that inherits its session from its schema. This fixes a bug where an exception was raised when usingNested
within aModelSchema
(:issue:`67`). Thanks :user:`nickw444` for reporting and thanks :user:`samueljsb` for the PR.
User code should be updated to use marshmallow-sqlalchemy's Nested
instead of marshmallow.fields.Nested
.
# Before
from marshmallow import fields
from marshmallow_sqlalchemy import ModelSchema
class ArtistSchema(ModelSchema):
class Meta:
model = models.Artist
class AlbumSchema(ModelSchema):
class Meta:
model = models.Album
artist = fields.Nested(ArtistSchema)
# After
from marshmallow import fields
from marshmallow_sqlalchemy import ModelSchema
from marshmallow_sqlalchemy.fields import Nested
class ArtistSchema(ModelSchema):
class Meta:
model = models.Artist
class AlbumSchema(ModelSchema):
class Meta:
model = models.Album
artist = Nested(ArtistSchema)
Features:
- Add support for
postgresql.MONEY
type (:issue:`218`). Thanks :user:`heckad` for the PR.
Bug fixes:
- Compatibility with marshmallow 3.0.0rc7. Thanks :user:`heckad` for the catch and patch.
Bug fixes:
- Compatibility with marshmallow 3.0.0rc6.
Bug fixes:
- Prevent ValueError when using the
exclude
class Meta option withTableSchema
(:pr:`202`).
Bug fixes:
- Fix compatibility with SQLAlchemy 1.3 (:issue:`185`).
Features:
- Add support for deserializing transient objects (:issue:`62`). Thanks :user:`jacksmith15` for the PR.
Features:
- Add
ModelConverter._should_exclude_field
hook (:pr:`139`). Thanks :user:`jeanphix` for the PR. - Allow field
kwargs
to be overriden by passinginfo['marshmallow']
to column properties (:issue:`21`). Thanks :user:`dpwrussell` for the suggestion and PR. Thanks :user:`jeanphix` for the final implementation.
Bug fixes:
- Fix behavior of
Related
field (:issue:`150`). Thanks :user:`zezic` for reporting and thanks :user:`AbdealiJK` for the PR. Related
now works withAssociationProxy
fields (:issue:`151`). Thanks :user:`AbdealiJK` for the catch and patch.
Other changes:
- Test against Python 3.7.
- Bring development environment in line with marshmallow.
Bug fixes:
- Fix behavior of
exclude
with marshmallow 3.0 (:issue:`131`). Thanks :user:`yaheath` for reporting and thanks :user:`deckar01` for the fix.
Features:
- Make
ModelSchema.session
a property, which allows session to be retrieved fromcontext
(:issue:`129`). Thanks :user:`gtxm`.
Other changes:
- Drop official support for Python 3.4. Python>=3.5 and Python 2.7 are supported.
Bug fixes:
- Unset
instance
attribute when an error occurs during aload
call (:issue:`114`). Thanks :user:`vgavro` for the catch and patch.
Bug fixes:
- Prevent unnecessary queries when using the fields.Related (:issue:`106`). Thanks :user:`xarg` for reporting and thanks :user:`jmuhlich` for the PR.
Features:
- Invalid inputs for compound primary keys raise a
ValidationError
when deserializing a scalar value (:issue:`103`). Thanks :user:`YuriHeupa` for the PR.
Bug fixes:
- Fix compatibility with marshmallow>=3.x.
Bug fixes:
- Reset
ModelSchema.instance
after eachload
call, allowing schema instances to be reused (:issue:`78`). Thanks :user:`georgexsh` for reporting.
Other changes:
- Test against Python 3.6.
Features:
- Add support for TypeDecorator-based types (:issue:`83`). Thanks :user:`frol`.
Bug fixes:
- Fix bug that caused a validation errors for custom column types that have the
python_type
ofuuid.UUID
(:issue:`54`). Thanks :user:`wkevina` and thanks :user:`kelvinhammond` for the fix.
Other changes:
- Drop official support for Python 3.3. Python>=3.4 and Python 2.7 are supported.
Features:
- Allow overriding field class returned by
field_for
by adding thefield_class
param (:issue:`81`). Thanks :user:`cancan101`.
Features:
- Support for SQLAlchemy JSON type (in SQLAlchemy>=1.1) (:issue:`74`). Thanks :user:`ewittle` for the PR.
Features:
- Enable deserialization of many-to-one nested objects that do not exist in the database (:issue:`69`). Thanks :user:`seanharr11` for the PR.
Bug fixes:
- Depend on SQLAlchemy>=0.9.7, since marshmallow-sqlalchemy uses
sqlalchemy.dialects.postgresql.JSONB
(:issue:`65`). Thanks :user:`alejom99` for reporting.
Bug fixes:
ModelSchema
andTableSchema
respect field order if theordered=True
class Meta option is set (:issue:`52`). Thanks :user:`jeffwidman` for reporting and :user:`jmcarp` for the patch.- Declared fields are not introspected in order to support, e.g.
column_property
(:issue:`57`). Thanks :user:`jmcarp`.
Features:
ModelSchema
andTableSchema
will respect theTYPE_MAPPING
class variable of Schema subclasses when convertingColumns
toFields
(:issue:`42`). Thanks :user:`dwieeb` for the suggestion.
Bug fixes:
- Don't make marshmallow fields required for non-nullable columns if a column has a default value or autoincrements (:issue:`47`). Thanks :user:`jmcarp` for the fix. Thanks :user:`AdrielVelazquez` for reporting.
Features:
- Add
include_fk
class Meta option (:issue:`36`). Thanks :user:`jmcarp`. - Non-nullable columns will generated required marshmallow Fields (:issue:`40`). Thanks :user:`jmcarp`.
- Improve support for MySQL BIT field (:issue:`41`). Thanks :user:`rudaporto`.
- Backwards-incompatible: Remove
fields.get_primary_columns
in favor offields.get_primary_keys
. - Backwards-incompatible: Remove
Related.related_columns
in favor offields.related_keys
.
Bug fixes:
- Fix serializing relationships when using non-default column names (:issue:`44`). Thanks :user:`jmcarp` for the fix. Thanks :user:`repole` for the bug report.
Features:
- Support for compound primary keys. Thanks :user:`jmcarp`.
Other changes:
- Supports marshmallow>=2.0.0.
- Add
instance
argument toModelSchema
constructor andModelSchema.load
which allows for updating existing DB rows (:issue:`26`). Thanks :user:`sssilver` for reporting and :user:`jmcarp` for the patch. - Don't autogenerate fields that are in
Meta.exclude
(:issue:`27`). Thanks :user:`jmcarp`. - Raise
ModelConversionError
if converting properties whose column don't define apython_type
. Thanks :user:`jmcarp`. - Backwards-incompatible:
ModelSchema.make_object
is removed in favor of decoratedmake_instance
method for compatibility with marshmallow>=2.0.0rc2.
Bug fixes:
- Now compatible with marshmallow>=2.0.0rc1.
- Correctly pass keyword arguments from
field_for
to generatedList
fields (:issue:`25`). Thanks :user:`sssilver` for reporting.
Features:
- Add
TableSchema
for generatingSchemas
from tables (:issue:`4`). Thanks :user:`jmcarp`.
Bug fixes:
- Allow
session
to be passed toModelSchema.validate
, since it requires it. Thanks :user:`dpwrussell`. - When serializing, don't skip overriden fields that are part of a polymorphic hierarchy (:issue:`18`). Thanks again :user:`dpwrussell`.
Support:
- Docs: Add new recipe for automatic generation of schemas. Thanks :user:`dpwrussell`.
Features:
- Backwards-incompatible: Relationships are (de)serialized by a new, more efficient
Related
column (:issue:`7`). Thanks :user:`jmcarp`. - Improve support for MySQL types (:issue:`1`). Thanks :user:`rmackinnon`.
- Improve support for Postgres ARRAY types (:issue:`6`). Thanks :user:`jmcarp`.
ModelSchema
no longer requires thesqla_session
class Meta option. ASession
can be passed to the constructor or to theModelSchema.load
method (:issue:`11`). Thanks :user:`dtheodor` for the suggestion.
Bug fixes:
- Null foreign keys are serialized correctly as
None
(:issue:`8`). Thanks :user:`mitchej123`. - Properly handle a relationship specifies
uselist=False
(:issue:`#17`). Thanks :user:`dpwrussell`.
Features:
- Add
field_for
function for generating marshmallow Fields from SQLAlchemy mapped class properties.
Support:
- Docs: Add "Overriding generated fields" section to "Recipes".
Bug fixes:
- Fix
keygetter
class Meta option.
- First release.