astra.database.apogee_drpdb¶
Module Contents¶
Classes¶
Base |
A helper class for ‘concrete’ declarative mappings. |
Visit |
A helper class for ‘concrete’ declarative mappings. |
Functions¶
define_relations() |
-
class
astra.database.apogee_drpdb.Base¶ A helper class for ‘concrete’ declarative mappings.
AbstractConcreteBasewill use thepolymorphic_union()function automatically, against all tables mapped as a subclass to this class. The function is called via the__declare_last__()function, which is essentially a hook for theafter_configured()event.AbstractConcreteBasedoes produce a mapped class for the base class, however it is not persisted to any table; it is instead mapped directly to the “polymorphic” selectable directly and is only used for selecting. Compare toConcreteBase, which does create a persisted table for the base class.Note
The
AbstractConcreteBaseclass does not intend to set up the mapping for the base class until all the subclasses have been defined, as it needs to create a mapping against a selectable that will include all subclass tables. In order to achieve this, it waits for the mapper configuration event to occur, at which point it scans through all the configured subclasses and sets up a mapping that will query against all subclasses at once.While this event is normally invoked automatically, in the case of
AbstractConcreteBase, it may be necessary to invoke it explicitly after all subclass mappings are defined, if the first operation is to be a query against this base class. To do so, invokeconfigure_mappers()once all the desired classes have been configured:from sqlalchemy.orm import configure_mappers configure_mappers()
See also
_orm.configure_mappers()Example:
from sqlalchemy.ext.declarative import AbstractConcreteBase class Employee(AbstractConcreteBase, Base): pass class Manager(Employee): __tablename__ = 'manager' employee_id = Column(Integer, primary_key=True) name = Column(String(50)) manager_data = Column(String(40)) __mapper_args__ = { 'polymorphic_identity':'manager', 'concrete':True} configure_mappers()
The abstract base class is handled by declarative in a special way; at class configuration time, it behaves like a declarative mixin or an
__abstract__base class. Once classes are configured and mappings are produced, it then gets mapped itself, but after all of its descendants. This is a very unique system of mapping not found in any other SQLAlchemy system.Using this approach, we can specify columns and properties that will take place on mapped subclasses, in the way that we normally do as in declarative_mixins:
class Company(Base): __tablename__ = 'company' id = Column(Integer, primary_key=True) class Employee(AbstractConcreteBase, Base): employee_id = Column(Integer, primary_key=True) @declared_attr def company_id(cls): return Column(ForeignKey('company.id')) @declared_attr def company(cls): return relationship("Company") class Manager(Employee): __tablename__ = 'manager' name = Column(String(50)) manager_data = Column(String(40)) __mapper_args__ = { 'polymorphic_identity':'manager', 'concrete':True} configure_mappers()
When we make use of our mappings however, both
ManagerandEmployeewill have an independently usable.companyattribute:session.query(Employee).filter(Employee.company.has(id=5))
Changed in version 1.0.0: - The mechanics of
AbstractConcreteBasehave been reworked to support relationships established directly on the abstract base, without any special configurational steps.See also
ConcreteBaseconcrete_inheritance
-
__abstract__= True¶
-
_schema= apogee_drp¶
-
_relations= define_relations¶
-
__table_args__¶
-
__no_table__= True¶
-
classmethod
__declare_first__(cls)¶
-
classmethod
_sa_decl_prepare_nocascade(cls)¶
-
classmethod
_sa_raise_deferred_config(cls)¶
-
classmethod
_create_polymorphic_union(cls, mappers, discriminator_name)¶
-
-
class
astra.database.apogee_drpdb.Visit¶ A helper class for ‘concrete’ declarative mappings.
AbstractConcreteBasewill use thepolymorphic_union()function automatically, against all tables mapped as a subclass to this class. The function is called via the__declare_last__()function, which is essentially a hook for theafter_configured()event.AbstractConcreteBasedoes produce a mapped class for the base class, however it is not persisted to any table; it is instead mapped directly to the “polymorphic” selectable directly and is only used for selecting. Compare toConcreteBase, which does create a persisted table for the base class.Note
The
AbstractConcreteBaseclass does not intend to set up the mapping for the base class until all the subclasses have been defined, as it needs to create a mapping against a selectable that will include all subclass tables. In order to achieve this, it waits for the mapper configuration event to occur, at which point it scans through all the configured subclasses and sets up a mapping that will query against all subclasses at once.While this event is normally invoked automatically, in the case of
AbstractConcreteBase, it may be necessary to invoke it explicitly after all subclass mappings are defined, if the first operation is to be a query against this base class. To do so, invokeconfigure_mappers()once all the desired classes have been configured:from sqlalchemy.orm import configure_mappers configure_mappers()
See also
_orm.configure_mappers()Example:
from sqlalchemy.ext.declarative import AbstractConcreteBase class Employee(AbstractConcreteBase, Base): pass class Manager(Employee): __tablename__ = 'manager' employee_id = Column(Integer, primary_key=True) name = Column(String(50)) manager_data = Column(String(40)) __mapper_args__ = { 'polymorphic_identity':'manager', 'concrete':True} configure_mappers()
The abstract base class is handled by declarative in a special way; at class configuration time, it behaves like a declarative mixin or an
__abstract__base class. Once classes are configured and mappings are produced, it then gets mapped itself, but after all of its descendants. This is a very unique system of mapping not found in any other SQLAlchemy system.Using this approach, we can specify columns and properties that will take place on mapped subclasses, in the way that we normally do as in declarative_mixins:
class Company(Base): __tablename__ = 'company' id = Column(Integer, primary_key=True) class Employee(AbstractConcreteBase, Base): employee_id = Column(Integer, primary_key=True) @declared_attr def company_id(cls): return Column(ForeignKey('company.id')) @declared_attr def company(cls): return relationship("Company") class Manager(Employee): __tablename__ = 'manager' name = Column(String(50)) manager_data = Column(String(40)) __mapper_args__ = { 'polymorphic_identity':'manager', 'concrete':True} configure_mappers()
When we make use of our mappings however, both
ManagerandEmployeewill have an independently usable.companyattribute:session.query(Employee).filter(Employee.company.has(id=5))
Changed in version 1.0.0: - The mechanics of
AbstractConcreteBasehave been reworked to support relationships established directly on the abstract base, without any special configurational steps.See also
ConcreteBaseconcrete_inheritance
-
__tablename__= visit¶
-
__abstract__= True¶
-
_schema= apogee_drp¶
-
_relations= define_relations¶
-
__table_args__¶
-
__no_table__= True¶
-
classmethod
__declare_first__(cls)¶
-
classmethod
_sa_decl_prepare_nocascade(cls)¶
-
classmethod
_sa_raise_deferred_config(cls)¶
-
classmethod
_create_polymorphic_union(cls, mappers, discriminator_name)¶
-
-
astra.database.apogee_drpdb.define_relations()¶