Class Mapping API — SQLAlchemy 1.3 Documentation (original) (raw)

Object Name Description
class_mapper(class_[, configure]) Given a class, return the primary Mapper associated with the key.
clear_mappers() Remove all mappers from all classes.
configure_mappers() Initialize the inter-mapper relationships of all mappers that have been constructed thus far.
identity_key(*args, **kwargs)
mapper(class_[, local_table, properties, primary_key, ...]) Return a new Mapper object.
Mapper Define the correlation of class attributes to database table columns.
object_mapper(instance) Given an object, return the primary Mapper associated with the object instance.
polymorphic_union(table_map, typecolname[, aliasname, cast_nulls]) Create a UNION statement used by a polymorphic mapper.

function sqlalchemy.orm.mapper(class_, local_table=None, properties=None, primary_key=None, non_primary=False, inherits=None, inherit_condition=None, inherit_foreign_keys=None, extension=None, order_by=False, always_refresh=False, version_id_col=None, version_id_generator=None, polymorphic_on=None, _polymorphic_map=None, polymorphic_identity=None, concrete=False, with_polymorphic=None, polymorphic_load=None, allow_partial_pks=True, batch=True, column_prefix=None, include_properties=None, exclude_properties=None, passive_updates=True, passive_deletes=False, confirm_deleted_rows=True, eager_defaults=False, legacy_is_orphan=False, _compiled_cache_size=100)

Return a new Mapper object.

This function is typically used behind the scenes via the Declarative extension. When using Declarative, many of the usual mapper() arguments are handled by the Declarative extension itself, including class_,local_table, properties, and inherits. Other options are passed to mapper() using the __mapper_args__ class variable:

class MyClass(Base): tablename = 'my_table' id = Column(Integer, primary_key=True) type = Column(String(50)) alt = Column("some_alt", Integer)

__mapper_args__ = {
    'polymorphic_on' : type
}

Explicit use of mapper()is often referred to as classical mapping. The above declarative example is equivalent in classical form to:

my_table = Table("my_table", metadata, Column('id', Integer, primary_key=True), Column('type', String(50)), Column("some_alt", Integer) )

class MyClass(object): pass

mapper(MyClass, my_table, polymorphic_on=my_table.c.type, properties={ 'alt':my_table.c.some_alt })

Parameters:

function sqlalchemy.orm.object_mapper(instance)

Given an object, return the primary Mapper associated with the object instance.

Raises sqlalchemy.orm.exc.UnmappedInstanceErrorif no mapping is configured.

This function is available via the inspection system as:

Using the inspection system will raisesqlalchemy.exc.NoInspectionAvailable if the instance is not part of a mapping.

function sqlalchemy.orm.class_mapper(class_, configure=True)

Given a class, return the primary Mapper associated with the key.

Raises UnmappedClassError if no mapping is configured on the given class, or ArgumentError if a non-class object is passed.

Equivalent functionality is available via the inspect()function as:

inspect(some_mapped_class)

Using the inspection system will raisesqlalchemy.exc.NoInspectionAvailable if the class is not mapped.

function sqlalchemy.orm.configure_mappers()

Initialize the inter-mapper relationships of all mappers that have been constructed thus far.

This function can be called any number of times, but in most cases is invoked automatically, the first time mappings are used, as well as whenever mappings are used and additional not-yet-configured mappers have been constructed.

Points at which this occur include when a mapped class is instantiated into an instance, as well as when the Session.query() method is used.

The configure_mappers() function provides several event hooks that can be used to augment its functionality. These methods include:

function sqlalchemy.orm.clear_mappers()

Remove all mappers from all classes.

This function removes all instrumentation from classes and disposes of their associated mappers. Once called, the classes are unmapped and can be later re-mapped with new mappers.

clear_mappers() is not for normal use, as there is literally no valid usage for it outside of very specific testing scenarios. Normally, mappers are permanent structural components of user-defined classes, and are never discarded independently of their class. If a mapped class itself is garbage collected, its mapper is automatically disposed of as well. As such, clear_mappers() is only for usage in test suites that re-use the same classes with different mappings, which is itself an extremely rare use case - the only such use case is in fact SQLAlchemy’s own test suite, and possibly the test suites of other ORM extension libraries which intend to test various combinations of mapper construction upon a fixed set of classes.

function sqlalchemy.orm.util.identity_key(*args, **kwargs)

Generate “identity key” tuples, as are used as keys in the

Session.identity_map dictionary.

This function has several call styles:

first()

identity_key(MyClass, row=row) (<class '__main__.MyClass'>, (1, 2), None)

param class:

mapped class (must be a positional argument)

param row:

RowProxy row returned by aResultProxy(must be given as a keyword arg)

param identity_token:

optional identity token

New in version 1.2: added identity_token

function sqlalchemy.orm.polymorphic_union(table_map, typecolname, aliasname='p_union', cast_nulls=True)

Create a UNION statement used by a polymorphic mapper.

See Concrete Table Inheritance for an example of how this is used.

Parameters:

class sqlalchemy.orm.Mapper(class_, local_table=None, properties=None, primary_key=None, non_primary=False, inherits=None, inherit_condition=None, inherit_foreign_keys=None, extension=None, order_by=False, always_refresh=False, version_id_col=None, version_id_generator=None, polymorphic_on=None, _polymorphic_map=None, polymorphic_identity=None, concrete=False, with_polymorphic=None, polymorphic_load=None, allow_partial_pks=True, batch=True, column_prefix=None, include_properties=None, exclude_properties=None, passive_updates=True, passive_deletes=False, confirm_deleted_rows=True, eager_defaults=False, legacy_is_orphan=False, _compiled_cache_size=100)

Define the correlation of class attributes to database table columns.

The Mapper object is instantiated using themapper() function. For information about instantiating new Mapper objects, see that function’s documentation.

When mapper() is used explicitly to link a user defined class with table metadata, this is referred to as classical mapping. Modern SQLAlchemy usage tends to favor thesqlalchemy.ext.declarative extension for class configuration, which makes usage of mapper() behind the scenes.

Given a particular class known to be mapped by the ORM, the Mapper which maintains it can be acquired using the inspect() function:

from sqlalchemy import inspect

mapper = inspect(MyClass)

A class which was mapped by the sqlalchemy.ext.declarativeextension will also have its mapper available via the __mapper__attribute.

Members

__init__(), add_properties(), add_property(), all_orm_descriptors, attrs, base_mapper, c, cascade_iterator(), class_, class_manager, column_attrs, columns, common_parent(), composites, concrete, configured, entity, get_property(), get_property_by_column(), identity_key_from_instance(), identity_key_from_primary_key(), identity_key_from_row(), inherits, is_mapper, isa(), iterate_properties, local_table, mapped_table, mapper, non_primary, persist_selectable, polymorphic_identity, polymorphic_iterator(), polymorphic_map, polymorphic_on, primary_key, primary_key_from_instance(), primary_mapper(), relationships, selectable, self_and_descendants, single, synonyms, tables, validators, with_polymorphic_mappers

method sqlalchemy.orm.Mapper.__init__(class_, local_table=None, properties=None, primary_key=None, non_primary=False, inherits=None, inherit_condition=None, inherit_foreign_keys=None, extension=None, order_by=False, always_refresh=False, version_id_col=None, version_id_generator=None, polymorphic_on=None, _polymorphic_map=None, polymorphic_identity=None, concrete=False, with_polymorphic=None, polymorphic_load=None, allow_partial_pks=True, batch=True, column_prefix=None, include_properties=None, exclude_properties=None, passive_updates=True, passive_deletes=False, confirm_deleted_rows=True, eager_defaults=False, legacy_is_orphan=False, _compiled_cache_size=100)

Construct a new Mapper object.

This constructor is mirrored as a public API function; see sqlalchemy.orm.mapper() for a full usage and argument description.

method sqlalchemy.orm.Mapper.add_properties(dict_of_properties)

Add the given dictionary of properties to this mapper, using add_property.

method sqlalchemy.orm.Mapper.add_property(key, prop)

Add an individual MapperProperty to this mapper.

If the mapper has not been configured yet, just adds the property to the initial properties dictionary sent to the constructor. If this Mapper has already been configured, then the given MapperProperty is configured immediately.

attribute sqlalchemy.orm.Mapper.all_orm_descriptors

A namespace of all InspectionAttr attributes associated with the mapped class.

These attributes are in all cases Python descriptorsassociated with the mapped class or its superclasses.

This namespace includes attributes that are mapped to the class as well as attributes declared by extension modules. It includes any Python descriptor type that inherits fromInspectionAttr. This includesQueryableAttribute, as well as extension types such ashybrid_property, hybrid_method andAssociationProxy.

To distinguish between mapped attributes and extension attributes, the attribute InspectionAttr.extension_type will refer to a constant that distinguishes between different extension types.

The sorting of the attributes is based on the following rules:

  1. Iterate through the class and its superclasses in order from subclass to superclass (i.e. iterate through cls.__mro__)
  2. For each class, yield the attributes in the order in which they appear in __dict__, with the exception of those in step 3 below. In Python 3.6 and above this ordering will be the same as that of the class’ construction, with the exception of attributes that were added after the fact by the application or the mapper.
  3. If a certain attribute key is also in the superclass __dict__, then it’s included in the iteration for that class, and not the class in which it first appeared.

The above process produces an ordering that is deterministic in terms of the order in which attributes were assigned to the class.

Changed in version 1.3.19: ensured deterministic ordering forMapper.all_orm_descriptors().

When dealing with a QueryableAttribute, theQueryableAttribute.property attribute refers to theMapperProperty property, which is what you get when referring to the collection of mapped properties viaMapper.attrs.

Warning

The Mapper.all_orm_descriptorsaccessor namespace is an instance of OrderedProperties. This is a dictionary-like object which includes a small number of named methods such as OrderedProperties.items()and OrderedProperties.values(). When accessing attributes dynamically, favor using the dict-access scheme, e.g. mapper.all_orm_descriptors[somename] overgetattr(mapper.all_orm_descriptors, somename) to avoid name collisions.

attribute sqlalchemy.orm.Mapper.attrs

A namespace of all MapperProperty objects associated this mapper.

This is an object that provides each property based on its key name. For instance, the mapper for aUser class which has User.name attribute would provide mapper.attrs.name, which would be theColumnProperty representing the namecolumn. The namespace object can also be iterated, which would yield each MapperProperty.

Mapper has several pre-filtered views of this attribute which limit the types of properties returned, including synonyms, column_attrs,relationships, and composites.

Warning

The Mapper.attrs accessor namespace is an instance of OrderedProperties. This is a dictionary-like object which includes a small number of named methods such as OrderedProperties.items()and OrderedProperties.values(). When accessing attributes dynamically, favor using the dict-access scheme, e.g. mapper.attrs[somename] overgetattr(mapper.attrs, somename) to avoid name collisions.

attribute sqlalchemy.orm.Mapper.base_mapper = None

The base-most Mapper in an inheritance chain.

In a non-inheriting scenario, this attribute will always be thisMapper. In an inheritance scenario, it references the Mapper which is parent to all other Mapperobjects in the inheritance chain.

This is a read only attribute determined during mapper construction. Behavior is undefined if directly modified.

attribute sqlalchemy.orm.Mapper.c = None

A synonym for Mapper.columns.

method sqlalchemy.orm.Mapper.cascade_iterator(type_, state, halt_on=None)

Iterate each element and its mapper in an object graph, for all relationships that meet the given cascade rule.

Parameters:

Returns:

the method yields individual object instances.

attribute sqlalchemy.orm.Mapper.class_ = None

The Python class which this Mapper maps.

This is a read only attribute determined during mapper construction. Behavior is undefined if directly modified.

attribute sqlalchemy.orm.Mapper.class_manager = None

The ClassManager which maintains event listeners and class-bound descriptors for this Mapper.

This is a read only attribute determined during mapper construction. Behavior is undefined if directly modified.

attribute sqlalchemy.orm.Mapper.column_attrs

Return a namespace of all ColumnPropertyproperties maintained by this Mapper.

attribute sqlalchemy.orm.Mapper.columns = None

A collection of Column or other scalar expression objects maintained by this Mapper.

The collection behaves the same as that of the c attribute on any Table object, except that only those columns included in this mapping are present, and are keyed based on the attribute name defined in the mapping, not necessarily the key attribute of theColumn itself. Additionally, scalar expressions mapped by column_property() are also present here.

This is a read only attribute determined during mapper construction. Behavior is undefined if directly modified.

method sqlalchemy.orm.Mapper.common_parent(other)

Return true if the given mapper shares a common inherited parent as this mapper.

attribute sqlalchemy.orm.Mapper.composites

Return a namespace of all CompositePropertyproperties maintained by this Mapper.

attribute sqlalchemy.orm.Mapper.concrete = None

Represent True if this Mapper is a concrete inheritance mapper.

This is a read only attribute determined during mapper construction. Behavior is undefined if directly modified.

attribute sqlalchemy.orm.Mapper.configured = None

Represent True if this Mapper has been configured.

This is a read only attribute determined during mapper construction. Behavior is undefined if directly modified.

See also

configure_mappers().

attribute sqlalchemy.orm.Mapper.entity

Part of the inspection API.

Returns self.class_.

method sqlalchemy.orm.Mapper.get_property(key, _configure_mappers=True)

return a MapperProperty associated with the given key.

method sqlalchemy.orm.Mapper.get_property_by_column(column)

Given a Column object, return theMapperProperty which maps this column.

method sqlalchemy.orm.Mapper.identity_key_from_instance(instance)

Return the identity key for the given instance, based on its primary key attributes.

If the instance’s state is expired, calling this method will result in a database check to see if the object has been deleted. If the row no longer exists,ObjectDeletedError is raised.

This value is typically also found on the instance state under the attribute name key.

method sqlalchemy.orm.Mapper.identity_key_from_primary_key(primary_key, identity_token=None)

Return an identity-map key for use in storing/retrieving an item from an identity map.

Parameters:

primary_key – A list of values indicating the identifier.

method sqlalchemy.orm.Mapper.identity_key_from_row(row, identity_token=None, adapter=None)

Return an identity-map key for use in storing/retrieving an item from the identity map.

Parameters:

row – A RowProxy instance. The columns which are mapped by this Mapper should be locatable in the row, preferably via the Columnobject directly (as is the case when a select() construct is executed), or via string names of the form <tablename>_<colname>.

attribute sqlalchemy.orm.Mapper.inherits = None

References the Mapper which this Mapperinherits from, if any.

This is a read only attribute determined during mapper construction. Behavior is undefined if directly modified.

attribute sqlalchemy.orm.Mapper.is_mapper = True

Part of the inspection API.

method sqlalchemy.orm.Mapper.isa(other)

Return True if the this mapper inherits from the given mapper.

attribute sqlalchemy.orm.Mapper.iterate_properties

return an iterator of all MapperProperty objects.

attribute sqlalchemy.orm.Mapper.local_table = None

The Selectable which this Mappermanages.

Typically is an instance of Table orAlias. May also be None.

The “local” table is the selectable that the Mapper is directly responsible for managing from an attribute access and flush perspective. For non-inheriting mappers, the local table is the same as the “mapped” table. For joined-table inheritance mappers, local_table will be the particular sub-table of the overall “join” which this Mapper represents. If this mapper is a single-table inheriting mapper, local_table will be None.

attribute sqlalchemy.orm.Mapper.mapped_table

Deprecated since version 1.3: Use .persist_selectable

attribute sqlalchemy.orm.Mapper.mapper

Part of the inspection API.

Returns self.

attribute sqlalchemy.orm.Mapper.non_primary = None

Represent True if this Mapper is a “non-primary” mapper, e.g. a mapper that is used only to select rows but not for persistence management.

This is a read only attribute determined during mapper construction. Behavior is undefined if directly modified.

attribute sqlalchemy.orm.Mapper.persist_selectable = None

The Selectable to which this Mapperis mapped.

Typically an instance of Table,Join, or Alias.

The Mapper.persist_selectable is separate fromMapper.selectable in that the former represents columns that are mapped on this class or its superclasses, whereas the latter may be a “polymorphic” selectable that contains additional columns which are in fact mapped on subclasses only.

“persist selectable” is the “thing the mapper writes to” and “selectable” is the “thing the mapper selects from”.

Mapper.persist_selectable is also separate fromMapper.local_table, which represents the set of columns that are locally mapped on this class directly.

attribute sqlalchemy.orm.Mapper.polymorphic_identity = None

Represent an identifier which is matched against theMapper.polymorphic_on column during result row loading.

Used only with inheritance, this object can be of any type which is comparable to the type of column represented byMapper.polymorphic_on.

This is a read only attribute determined during mapper construction. Behavior is undefined if directly modified.

method sqlalchemy.orm.Mapper.polymorphic_iterator()

Iterate through the collection including this mapper and all descendant mappers.

This includes not just the immediately inheriting mappers but all their inheriting mappers as well.

To iterate through an entire hierarchy, usemapper.base_mapper.polymorphic_iterator().

attribute sqlalchemy.orm.Mapper.polymorphic_map = None

A mapping of “polymorphic identity” identifiers mapped toMapper instances, within an inheritance scenario.

The identifiers can be of any type which is comparable to the type of column represented by Mapper.polymorphic_on.

An inheritance chain of mappers will all reference the same polymorphic map object. The object is used to correlate incoming result rows to target mappers.

This is a read only attribute determined during mapper construction. Behavior is undefined if directly modified.

attribute sqlalchemy.orm.Mapper.polymorphic_on = None

The Column or SQL expression specified as thepolymorphic_on argument for this Mapper, within an inheritance scenario.

This attribute is normally a Column instance but may also be an expression, such as one derived fromcast().

This is a read only attribute determined during mapper construction. Behavior is undefined if directly modified.

attribute sqlalchemy.orm.Mapper.primary_key = None

An iterable containing the collection of Columnobjects which comprise the ‘primary key’ of the mapped table, from the perspective of this Mapper.

This list is against the selectable inMapper.persist_selectable. In the case of inheriting mappers, some columns may be managed by a superclass mapper. For example, in the case of aJoin, the primary key is determined by all of the primary key columns across all tables referenced by the Join.

The list is also not necessarily the same as the primary key column collection associated with the underlying tables; the Mapperfeatures a primary_key argument that can override what theMapper considers as primary key columns.

This is a read only attribute determined during mapper construction. Behavior is undefined if directly modified.

method sqlalchemy.orm.Mapper.primary_key_from_instance(instance)

Return the list of primary key values for the given instance.

If the instance’s state is expired, calling this method will result in a database check to see if the object has been deleted. If the row no longer exists,ObjectDeletedError is raised.

method sqlalchemy.orm.Mapper.primary_mapper()

Return the primary mapper corresponding to this mapper’s class key (class).

attribute sqlalchemy.orm.Mapper.relationships

A namespace of all RelationshipProperty properties maintained by this Mapper.

Warning

the Mapper.relationships accessor namespace is an instance of OrderedProperties. This is a dictionary-like object which includes a small number of named methods such as OrderedProperties.items()and OrderedProperties.values(). When accessing attributes dynamically, favor using the dict-access scheme, e.g. mapper.relationships[somename] overgetattr(mapper.relationships, somename) to avoid name collisions.

attribute sqlalchemy.orm.Mapper.selectable

The select() construct this Mapperselects from by default.

Normally, this is equivalent to persist_selectable, unless the with_polymorphic feature is in use, in which case the full “polymorphic” selectable is returned.

attribute sqlalchemy.orm.Mapper.self_and_descendants

The collection including this mapper and all descendant mappers.

This includes not just the immediately inheriting mappers but all their inheriting mappers as well.

attribute sqlalchemy.orm.Mapper.single = None

Represent True if this Mapper is a single table inheritance mapper.

Mapper.local_table will be None if this flag is set.

This is a read only attribute determined during mapper construction. Behavior is undefined if directly modified.

attribute sqlalchemy.orm.Mapper.synonyms

Return a namespace of all SynonymPropertyproperties maintained by this Mapper.

attribute sqlalchemy.orm.Mapper.tables = None

An iterable containing the collection of Table objects which this Mapper is aware of.

If the mapper is mapped to a Join, or anAliasrepresenting a Select, the individualTableobjects that comprise the full construct will be represented here.

This is a read only attribute determined during mapper construction. Behavior is undefined if directly modified.

attribute sqlalchemy.orm.Mapper.validators = None

An immutable dictionary of attributes which have been decorated using the validates() decorator.

The dictionary contains string attribute names as keys mapped to the actual validation method.

attribute sqlalchemy.orm.Mapper.with_polymorphic_mappers

The list of Mapper objects included in the default “polymorphic” query.