类映射API

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, 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)

返回一个新的Mapper对象。

该功能通常通过声明扩展在幕后使用。当使用Declarative时,许多通常的mapper()参数由Declarative扩展本身处理,包括class_local_tablepropertiesinherits其他选项使用__mapper_args__类变量传递给mapper()

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
    }

显式使用mapper()通常被称为经典映射上面的声明性示例在经典形式上等同于:

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
    })

也可以看看

Classical Mappings - 讨论直接使用mapper()

参数:
  • class _ - 要映射的类。当使用Declarative时,这个参数会自动作为声明的类本身传递。
  • local_table – The Table or other selectable to which the class is mapped. 如果此映射器使用单表继承从另一个映射器继承,则可能为NoneWhen using Declarative, this argument is automatically passed by the extension, based on what is configured via the __table__ argument or via the Table produced as a result of the __tablename__ and Column arguments present.
  • always_refresh – If True, all query operations for this mapped class will overwrite all data within object instances that already exist within the session, erasing any in-memory changes with whatever information was loaded from the database. 高度不鼓励使用这个标志;作为替代方法,请参阅方法Query.populate_existing()
  • allow_partial_pks - 默认为True。指示具有一些NULL值的组合主键应被视为可能存在于数据库中。This affects whether a mapper will assign an incoming row to an existing identity, as well as if Session.merge() will check the database first for a particular primary key value. 例如,如果已映射到​​OUTER JOIN,则可能发生“部分主键”。
  • batch – Defaults to True, indicating that save operations of multiple entities can be batched together for efficiency. 设置为False表示在保存下一个实例之前,实例将完全保存。这是极少数情况下使用的,即MapperEvents侦听器需要在各个行持久性操作之间调用。
  • column_prefix -

    Column对象被自动指定为映射类的属性时,该字符串将被映射到映射属性名称的前面。不会影响显式指定的基于列的属性。

    示例中的Naming All Columns with a Prefix部分。

  • 具体 -

    如果为True,则表示此映射器应该使用其父映射器的具体表继承。

    例如,请参阅Concrete Table Inheritance部分。

  • confirm_deleted_rows -

    默认为True;当基于特定主键的DELETE出现多一行时,如果匹配的行数不等于期望的行数,则会发出警告。可以将此参数设置为False来处理数据库ON DELETE CASCADE规则可能会自动删除其中某些行的情况。警告可能会更改为未来版本中的例外情况。

    版本0.9.4中的新增功能: - 添加了mapper.confirm_deleted_rows以及条件匹配的行删除检查。

  • eager_defaults -

    如果为True,ORM将在INSERT或UPDATE后立即获取服务器生成的默认值的值,而不是在下次访问时将它们保留为过期值。这可以用于在flush完成之前立即需要服务器生成的值的事件方案。默认情况下,该方案将在插入或更新的每行中发出单独的SELECT语句,该注释可能会增加显着的性能开销。但是,如果目标数据库支持RETURNING,则默认值将以INSERT或UPDATE语句内联返回,这可以极大地提高需要频繁访问刚刚生成的服务器默认值的应用程序的性能。

    在版本0.9.0中更改: eager_defaults选项现在可以使用RETURNING作为支持它的后端。

  • exclude_properties -

    要从映射中排除的列表或一组字符串列名称。

    例如,请参阅Mapping a Subset of Table Columns

  • extension – A MapperExtension instance or list of MapperExtension instances which will be applied to all operations by this Mapper. 已过时。 T0>请参阅MapperEvents
  • include_properties -

    一个包含列表或一组要包含的字符串列名。

    例如,请参阅Mapping a Subset of Table Columns

  • 继承 -

    一个映射类或相应的Mapper,表示该Mapper应该继承的超类。这里映射的类必须是其他映射器类的子类。当使用Declarative时,由于声明的类的自然类层次结构而自动传递此参数。

  • inherit_condition – For joined table inheritance, a SQL expression which will define how the two tables are joined; defaults to a natural join between the two tables.
  • inherit_foreign_keys – When inherit_condition is used and the columns present are missing a ForeignKey configuration, this parameter can be used to specify which columns are “foreign”. 在大多数情况下,可以保留为None
  • legacy_is_orphan -

    布尔值,默认为FalseTrue时,指定将“遗留”孤儿考虑应用于由此映射器映射的对象,这意味着挂起(即非持久)对象从拥有Session,只有当它从全部父母指定一个delete-orphan级联到此映射器时,才会关联。新的默认行为是,当该对象与指定delete-orphan级联的其父母的任何关联时,该对象会自动清除。这种行为与持久化对象的行为更加一致,并且允许行为在更多场景中保持一致,而与是否已经刷新了可签发对象无关。

    请参阅The consideration of a “pending” object as an “orphan” has been made more aggressive

    0.8版新增功能: - 将待处理对象视为“孤立对象”的修改已被修改为与持久对象的行为更加接近,即对象从Session,只要它从任何孤立启用的父母中解除关联。以前,挂起的对象只有在与所有孤立启用的父母关联时才会被清除。新标志legacy_is_orphan被添加到orm.mapper()中,以重新建立传统行为。

  • non_primary -

    指定该Mapper是“主”映射程序的补充,即用于持久化的映射程序。这里创建的Mapper可用于类的临时映射到备选可选项,仅用于加载。

    Mapper.non_primary不是一个经常使用的选项,但在某些特定的relationship()情况下很有用。

  • order_by -

    一个ColumnColumn对象列表,选择操作应将其用作实体的默认排序。默认情况下,映射器没有预定义的顺序。

    从版本1.1开始弃用:不推荐使用Mapper.order_by参数。使用Query.order_by()确定结果集的排序。

  • passive_deletes -

    指示删除连接表继承实体时,外键列的DELETE行为。对于基本映射器,默认为False;对于继承映射器,默认为False,除非超类映射器上的值设置为True

    True时,假定ON DELETE CASCADE配置在将此映射器表与其超类表关联的外键关系上,以便当工作单元试图删除实体时,它只需要为超类表发出DELETE语句,而不是此表。

    False时,会为此映射器的表单独发出DELETE语句。如果这个表的本地主键属性被卸载,那么必须发出一个SELECT来验证这些属性;请注意,连接表子类的主键列不是整个对象的“主键”的一部分。

    请注意,True的值始终是强制到子类映射器上;也就是说,超类无法指定passive_deletes,而这对所有子类映射器都不起作用。

    版本1.1中的新功能

    也可以看看

    Using Passive Deletes - 与relationship()一起使用的相似功能的描述

    mapper.passive_updates - 支持连接表继承映射器的ON UPDATE CASCADE

  • passive_updates -

    指示主键列在连接表继承映射上发生更改时外键列的UPDATE行为。默认为True

    如果为True,则假定在数据库的外键上配置了ON UPDATE CASCADE,并且数据库将处理UPDATE从源列传播到连接表行上的从属列。

    如果为False,则假定数据库不强制执行参照完整性,并且不会为更新发布自己的CASCADE操作。工作单元过程将在主键更改期间为从属列发出UPDATE语句。

    也可以看看

    Mutable Primary Keys / Update Cascades - 与relationship()一起使用的相似特征的描述

    mapper.passive_deletes - 为连接表继承映射器支持ON DELETE CASCADE

  • polymorphic_on -

    当存在继承类时,指定用于确定传入行的目标类的列,属性或SQL表达式。

    该值通常是存在于映射的Table中的Column对象:

    class Employee(Base):
        __tablename__ = 'employee'
    
        id = Column(Integer, primary_key=True)
        discriminator = Column(String(50))
    
        __mapper_args__ = {
            "polymorphic_on":discriminator,
            "polymorphic_identity":"employee"
        }

    它也可以被指定为一个SQL表达式,就像在这个例子中我们使用case()结构来提供一个条件方法:

    class Employee(Base):
        __tablename__ = 'employee'
    
        id = Column(Integer, primary_key=True)
        discriminator = Column(String(50))
    
        __mapper_args__ = {
            "polymorphic_on":case([
                (discriminator == "EN", "engineer"),
                (discriminator == "MA", "manager"),
            ], else_="employee"),
            "polymorphic_identity":"employee"
        }

    它也可以引用用column_property()配置的任何属性,或者指向一个字符串名称的属性:

    class Employee(Base):
        __tablename__ = 'employee'
    
        id = Column(Integer, primary_key=True)
        discriminator = Column(String(50))
        employee_type = column_property(
            case([
                (discriminator == "EN", "engineer"),
                (discriminator == "MA", "manager"),
            ], else_="employee")
        )
    
        __mapper_args__ = {
            "polymorphic_on":employee_type,
            "polymorphic_identity":"employee"
        }

    在版本0.7.4中进行了更改: polymorphic_on可以指定为SQL表达式,或者参考使用column_property()配置的任何属性,一个字符串的名称。

    当设置polymorphic_on引用本地映射的Table中不存在的属性或表达式时,鉴别器的值应该持久保存到数据库中,鉴别器的值不会自动设置在新实例上;这必须由用户通过手动方式或通过事件监听器来处理。建立这样一个听众的典型方法如下所示:

    from sqlalchemy import event
    from sqlalchemy.orm import object_mapper
    
    @event.listens_for(Employee, "init", propagate=True)
    def set_identity(instance, *arg, **kw):
        mapper = object_mapper(instance)
        instance.discriminator = mapper.polymorphic_identity

    如上所述,我们将映射类的polymorphic_identity的值赋给discriminator属性,从而将值保存到数据库中的discriminator列。

    警告

    目前,只能设置一个鉴别器列,通常位于层次结构中最底层的类。“级联”多态列还不被支持。

  • polymorphic_identity – Specifies the value which identifies this particular class as returned by the column expression referred to by the polymorphic_on setting. 在接收到行时,将与polymorphic_on列表达式相对应的值与此值进行比较,指示哪个子类应该用于新重建的对象。
  • properties – A dictionary mapping the string names of object attributes to MapperProperty instances, which define the persistence behavior of that attribute. 请注意,映射后的Table中存在的Column对象会自动放入ColumnProperty实例中,除非被覆盖。当使用Declarative时,基于所声明的类体中声明的所有MapperProperty实例自动传递此参数。
  • primary_key – A list of Column objects which define the primary key to be used against this mapper’s selectable unit. 这通常只是local_table的主键,但可以在此处重写。
  • version_id_col -

    一个Column,用于保留表中行的正在运行的版本标识。这用于检测并发更新或在刷新中存在陈旧数据。该方法是检测UPDATE语句是否与最后一个已知版本ID不匹配,引发StaleDataError异常。默认情况下,除非version_id_generator指定了替代版本生成器,否则该列必须为Integer类型。

    也可以看看

    Configuring a Version Counter - 讨论版本计数和基本原理。

  • version_id_generator -

    定义应该如何生成新版本的ID。默认为None,这表示使用简单的整数计数方案。要提供自定义版本控制方案,请提供表单的可调用函数:

    def generate_version(version):
        return next_version

    另外,通过指定值False,可以使用服务器端版本控制功能,例如触发器或版本ID生成器以外的程序版本控制方案。使用此选项时,请参阅Server Side Version Counters以了解重要的一点。

    版本0.9.0新增: version_id_generator支持服务器端版本号的生成。

  • with_polymorphic -

    指示“多态”加载的默认样式的(< classes>, < selectable>)形式的元组,哪些表一次被查询。是映射器和/或类的任何单个或列表,指示应该一次加载的继承类。 T0>特殊值'*'可用于指示所有降序类应立即加载。第二个元组参数表示将用于查询多个类的可选项。

    也可以看看

    Basic Control of Which Tables are Queried - 讨论多态查询技术。

sqlalchemy.orm。 T0> object_mapper T1> ( T2> 实例 T3> ) T4> ¶ T5 >

给定一个对象,返回与对象实例关联的主映射器。

如果未配置映射,则引发sqlalchemy.orm.exc.UnmappedInstanceError

该功能可通过检查系统获得:

inspect(instance).mapper

如果实例不是映射的一部分,则使用检查系统将引发sqlalchemy.exc.NoInspectionAvailable

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

给定一个类,返回与密钥关联的主要Mapper

如果给定类没有配置映射,则引发UnmappedClassError;如果传递了非类对象,则引发ArgumentError

等效功能可通过inspect()函数使用:

inspect(some_mapped_class)

如果该类未映射,则使用检查系统将引发sqlalchemy.exc.NoInspectionAvailable

sqlalchemy.orm。 T0> configure_mappers T1> ( T2> ) T3> ¶ T4>

初始化到目前为止已经构建的所有映射器的映射器间关系。

这个函数可以调用任意次数,但在大多数情况下会自动调用,使用第一次映射,以及每当使用映射和额外尚未配置的映射器已经构建。

出现这种情况的要点包括何时将映射类实例化为实例,以及何时使用Session.query()方法。

configure_mappers()函数提供了几个可用于扩充其功能的事件挂钩。这些方法包括:

sqlalchemy.orm。 T0> clear_mappers T1> ( T2> ) T3> ¶ T4>

从所有类中移除所有映射器。

这个函数从类中移除所有的工具并处理它们相关的映射器。一旦被调用,这些类就会被取消映射,并可以在以后用新的映射器重新映射。

clear_mappers() is not for normal use, as there is literally no valid usage for it outside of very specific testing scenarios. 通常,映射器是用户定义类的永久性结构组件,并且不会独立于类而丢弃它。如果一个映射类本身被垃圾收集,它的映射器也会自动处理。因此,clear_mappers()仅用于测试套件中,该测试套件将重复使用具有不同映射的相同类,这本身就是极其罕见的用例 - 唯一的这种用例实际上是SQLAlchemy自己的测试套件以及可能的其他ORM扩展库的测试套件,这些扩展库打算根据固定的一组类来测试映射器构造的各种组合。

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

生成“身份密钥”元组,就像在Session.identity_map字典中用作键一样。

这个函数有几种调用方式:

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

创建一个由多态映射器使用的UNION语句。

有关如何使用它的示例,请参阅Concrete Table Inheritance

参数:
  • table_map – mapping of polymorphic identities to Table objects.
  • typecolname – string name of a “discriminator” column, which will be derived from the query, producing the polymorphic identity for each row. 如果None,则不会生成多态鉴别符。
  • aliasname – name of the alias() construct generated.
  • cast_nulls – if True, non-existent columns, which are represented as labeled NULLs, will be passed into CAST. 这是一个遗留问题,在Oracle的一些后端存在问题 - 在这种情况下,它可以设置为False。
class sqlalchemy.orm.mapper.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, 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)

基础:sqlalchemy.orm.base.InspectionAttr

定义类属性与数据库表列的关联。

Mapper对象使用mapper()函数实例化。有关实例化新的Mapper对象的信息,请参阅该函数的文档。

mapper()明确用于链接用户定义的类和表元数据时,这被称为经典映射现代SQLAlchemy用法倾向于支持类配置的sqlalchemy.ext.declarative扩展,这使得在后台使用mapper()

给定一个已知由ORM映射的类,可以使用inspect()函数获取维护它的Mapper

from sqlalchemy import inspect

mapper = inspect(MyClass)

sqlalchemy.ext.declarative扩展名映射的类也将通过__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, 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)

构建一个新的Mapper对象。

这个构造函数被镜像为公共API函数;有关完整的用法和参数描述,请参阅mapper()

add_properties T0> ( T1> dict_of_properties T2> ) T3> ¶ T4>

使用add_property将给定的属性字典添加到此映射器中。

add_property(key, prop)

添加一个单独的MapperProperty到这个映射器。

如果映射器尚未配置,只需将该属性添加到发送给构造函数的初始属性字典中即可。如果这个Mapper已经配置完毕,那么给定的MapperProperty会立即配置。

all_orm_descriptors T0> ¶ T1>

与映射类关联的所有InspectionAttr属性的名称空间。

这些属性在所有情况下都是与映射类或其超类关联的Python descriptors

该名称空间包括映射到该类的属性以及由扩展模块声明的属性。它包含从InspectionAttr继承的任何Python描述符类型。这包括QueryableAttribute以及扩展类型,例如hybrid_propertyhybrid_methodAssociationProxy

为了区分映射属性和扩展属性,属性InspectionAttr.extension_type将引用区分不同扩展类型的常量。

在处理QueryableAttribute时,QueryableAttribute.property属性指向MapperProperty属性,这是您在引用映射集合时获得的通过Mapper.attrs的属性。

警告

Mapper.all_orm_descriptors访问器名称空间是OrderedProperties的一个实例。这是一个类似字典的对象,它包含少量的命名方法,如OrderedProperties.items()OrderedProperties.values()When accessing attributes dynamically, favor using the dict-access scheme, e.g. mapper.all_orm_descriptors[somename] over getattr(mapper.all_orm_descriptors, somename) to avoid name collisions.

0.8.0版本中的新功能

也可以看看

Mapper.attrs

ATTRS T0> ¶ T1>

所有MapperProperty对象的名称空间都与此映射器关联。

这是一个基于其关键名称提供每个属性的对象。例如,具有User.name属性的User类的映射器将提供mapper.attrs.name,它将是ColumnProperty表示name列。命名空间对象也可以迭代,这会产生每个MapperProperty

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

警告

Mapper.attrs访问器名称空间是OrderedProperties的实例。这是一个类似字典的对象,它包含少量的命名方法,如OrderedProperties.items()OrderedProperties.values()When accessing attributes dynamically, favor using the dict-access scheme, e.g. mapper.attrs[somename] over getattr(mapper.attrs, somename) to avoid name collisions.

base_mapper =无

继承链中最基本的Mapper

在非继承场景中,该属性将始终是Mapper在继承场景中,它引用了Mapper,它是继承链中所有其他Mapper对象的父对象。

这是在映射器构建期间确定的只读属性。如果直接修改,行为是未定义的。

c =无

columns

cascade_iterator(type_, state, halt_on=None)

迭代对象图中的每个元素及其映射器,以满足给定级联规则的所有关系。

参数:
返回:

该方法产生单独的对象实例。

也可以看看

Cascades

How do I walk all objects that are related to a given object? - 说明了不依赖级联而遍历所有对象的通用函数。

class _ =无

这个Mapper映​​射的Python类。

这是在映射器构建期间确定的只读属性。如果直接修改,行为是未定义的。

class_manager =无

ClassManager,它为这个Mapper维护事件侦听器和类绑定描述符。

这是在映射器构建期间确定的只读属性。如果直接修改,行为是未定义的。

column_attrs T0> ¶ T1>

返回由Mapper维护的所有ColumnProperty属性的命名空间。

也可以看看

Mapper.attrs - 所有MapperProperty对象的命名空间。

=无

Mapper维护的Column或其他标量表达式对象的集合。

该集合的行为与任何Table对象的c属性的行为相同,区别仅在于此映射中包含的那些列存在,并且基于属性名称在映射中定义,不一定是Column本身的key属性。另外,这里还存在由column_property()映​​射的标量表达式。

这是在映射器构建期间确定的只读属性。如果直接修改,行为是未定义的。

common_parent T0> ( T1> 其他 T2> ) T3> ¶ T4>

如果给定的映射器与此映射器共享共同的继承父项,则返回true。

复合材料 T0> ¶ T1>

返回由Mapper维护的所有CompositeProperty属性的命名空间。

也可以看看

Mapper.attrs - 所有MapperProperty对象的命名空间。

具体 =无

如果Mapper是一个具体的继承映射器,则表示True

这是在映射器构建期间确定的只读属性。如果直接修改,行为是未定义的。

已配置 =无

如果已经配置Mapper,则表示True

这是在映射器构建期间确定的只读属性。如果直接修改,行为是未定义的。

也可以看看

configure_mappers()

实体 T0> ¶ T1>

检查API的一部分。

返回self.class_。

get_property key_configure_mappers = True t5 >

返回与给定键相关联的MapperProperty。

get_property_by_column T0> ( T1> 列 T2> ) T3> ¶ T4>

给定一个Column对象,返回映射此列的MapperProperty

identity_key_from_instance T0> ( T1> 实例 T2> ) T3> ¶ T4>

根据主键属性返回给定实例的身份关键字。

如果实例的状态已过期,则调用此方法将导致数据库检查以查看该对象是否已被删除。如果该行不再存在,则引发ObjectDeletedError

该值通常也可以在属性名称下的实例状态中找到。

identity_key_from_primary_key T0> ( T1> primary_key T2> ) T3> ¶ T4>

返回身份地图密钥以用于存储/检索身份地图中的项目。

参数: primary_key - 指示标识符的值列表。
identity_key_from_row rowadapter = None t5 >

返回身份地图密钥,用于从身份地图中存储/检索项目。

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

引用这个Mapper继承的Mapper,如果有的话。

这是在映射器构建期间确定的只读属性。如果直接修改,行为是未定义的。

is_mapper = True

检查API的一部分。

赛 T0> ( T1> 其他 T2> ) T3> ¶ T4>

如果此映射器从给定的映射器继承,则返回True。

iterate_properties T0> ¶ T1>

返回所有MapperProperty对象的迭代器。

local_table =无

这个Mapper管理的Selectable

通常是TableAlias的实例。也可以是None

“本地”表是Mapper直接负责从属性访问和刷新角度管理的可选项。对于非继承映射器,本地表与“映射”表相同。对于连接表继承映射器,local_table将是这个Mapper所代表的整体“连接”的特定子表。如果这个映射器是一个单表继承映射器,local_table将是None

也可以看看

mapped_table

mapped_table =无

Mapper映射到的Selectable

通常是TableJoinAlias的实例。

“映射”表是映射器在查询期间选择的可选项。对于非继承映射器,映射表与“本地”表相同。对于连接表继承映射器,mapped_table引用表示此特定子类的完整行的完整Join对于单表继承映射器,mapped_table引用基表。

也可以看看

local_table

映射器 T0> ¶ T1>

检查API的一部分。

返回自我。

non_primary =无

如果Mapper是一个“非主要”映射器,则表示True。一个仅用于分隔行但不用于持久性管理的映射器。

这是在映射器构建期间确定的只读属性。如果直接修改,行为是未定义的。

polymorphic_identity =无

表示结果行加载过程中与polymorphic_on列匹配的标识符。

仅用于继承,此对象可以是任何类型,与polymorphic_on表示的列的类型相当。

这是在映射器构建期间确定的只读属性。如果直接修改,行为是未定义的。

polymorphic_iterator T0> ( T1> ) T2> ¶ T3>

遍历包含该映射器和所有后代映射器的集合。

这不仅包括立即继承的映射器,还包括它们的所有继承映射器。

要遍历整个层次结构,请使用mapper.base_mapper.polymorphic_iterator()

polymorphic_map =无

在继承场景中映射到Mapper实例的“多态身份”标识符的映射。

标识符可以是任何类型,与polymorphic_on表示的列的类型相当。

映射器的继承链将全部引用相同的多态映射对象。该对象用于将传入结果行关联到目标映射器。

这是在映射器构建期间确定的只读属性。如果直接修改,行为是未定义的。

polymorphic_on =无

在继承方案中,Column或SQL表达式被指定为该Mapperpolymorphic_on参数。

该属性通常是一个Column实例,但也可能是一个表达式,例如从cast()派生的表达式。

这是在映射器构建期间确定的只读属性。如果直接修改,行为是未定义的。

primary_key =无

Mapper的角度来看,一个迭代器包含Column对象的集合,该对象构成映射表的“主键”。

该列表与mapped_table中的可选列表相反。在继承映射器的情况下,某些列可能由超类映射器管理。例如,对于Join,主键由Join引用的所有表中的所有主键列确定。

该列表也不一定与与基础表关联的主键列集合相同; Mapper具有primary_key参数,可以覆盖Mapper认为的主键列。

这是在映射器构建期间确定的只读属性。如果直接修改,行为是未定义的。

primary_key_from_instance T0> ( T1> 实例 T2> ) T3> ¶ T4>

返回给定实例的主键值列表。

如果实例的状态已过期,则调用此方法将导致数据库检查以查看该对象是否已被删除。如果该行不再存在,则引发ObjectDeletedError

primary_mapper T0> ( T1> ) T2> ¶ T3>

返回与此映射器的类关键字(类)相对应的主映射器。

关系 T0> ¶ T1>

Mapper维护的所有RelationshipProperty属性的命名空间。

警告

Mapper.relationships存取器名称空间是OrderedProperties的一个实例。这是一个类似字典的对象,它包含少量的命名方法,如OrderedProperties.items()OrderedProperties.values()When accessing attributes dynamically, favor using the dict-access scheme, e.g. mapper.relationships[somename] over getattr(mapper.relationships, somename) to avoid name collisions.

也可以看看

Mapper.attrs - 所有MapperProperty对象的命名空间。

可选 T0> ¶ T1>

这个Mapper构造的select()构造默认选择。

通常情况下,这相当于mapped_table,除非使用with_polymorphic功能,在这种情况下,将返回完整的“多态”选择。

self_and_descendants T0> ¶ T1>

包含这个映射器和所有后代映射器的集合。

这不仅包括立即继承的映射器,还包括它们的所有继承映射器。

=无

如果Mapper是单表继承映射器,则表示True

local_table will be None if this flag is set.

这是在映射器构建期间确定的只读属性。如果直接修改,行为是未定义的。

同义词 T0> ¶ T1>

返回由Mapper维护的所有SynonymProperty属性的名称空间。

也可以看看

Mapper.attrs - 所有MapperProperty对象的命名空间。

表格 =无

一个迭代器,包含Mapper所知的Table对象的集合。

如果映射器映射到JoinAlias表示Select,则包含Table对象完整的构造将在这里呈现。

这是在映射器构建期间确定的只读属性。如果直接修改,行为是未定义的。

验证器 =无

使用validates()装饰器修饰过的属性的不可变字典。

该字典包含字符串属性名称作为映射到实际验证方法的键。

with_polymorphic_mappers T0> ¶ T1>

包含在默认“多态”查询中的Mapper对象列表。