0

Mapper Argument を使用してテーブルを定義するクラスがあります。polymorphic_on: column

このクラスを継承する他のクラスがいくつかあり、それらはすべて設定する必要があり__mapper_args__ 'polymorphic_identity'ます。これは、クラス定義内で設定するのではなく、クラスが定義された後に行いたいと考えています。

クラスが定義された後に polymorphic_identity マッパー引数を設定するにはどうすればよいですか?

ありがとうございました。

4

1 に答える 1

3

これは完全にパブリックな API ではありませんが、動作するはずです:

from sqlalchemy.orm import class_mapper
mapper = class_mapper(MySubClass)
mapper.polymorphic_identity = "some_identity"
mapper.polymorphic_map["some_identity"] = mapper
# in 0.8, might try to fix this for 0.9
mapper._identity_class = mapper.inherits._identity_class

これは機能としてサポートできるものなので、自由に機能リクエストを追加してください。

編集:宣言を使用したテストは次のとおりです。

from sqlalchemy import *
from sqlalchemy.orm import *
from sqlalchemy.ext.declarative import declarative_base

from sqlalchemy.orm import class_mapper

Base= declarative_base()


class A(Base):
    __tablename__ = "a"

    id = Column(Integer, primary_key=True)
    type = Column(String)
    __mapper_args__ = {"polymorphic_on": type, "polymorphic_identity": "a"}

class B(A):
    pass

mapper = class_mapper(B)
mapper.polymorphic_identity = "b"
mapper.polymorphic_map["b"] = mapper

e = create_engine("sqlite://", echo=True)

Base.metadata.create_all(e)

s = Session(e)

s.add_all([A(), B(), B(), A(), A()])
s.commit()

s.close()

assert [obj.type for obj in s.query(B).order_by(A.id)] \
            == ['b', 'b']

assert [type(obj) for obj in s.query(B).order_by(A.id)] \
            == [B, B]

assert [obj.type for obj in s.query(A).order_by(A.id)] \
            == ['a', 'b', 'b', 'a', 'a']
于 2013-02-28T00:29:47.883 に答える