У меня есть модель
class CreatedMixin(object):
__abstract__ = True
@declared_attr
def created_by(cls):
return Column(Integer, ForeignKey('user.user_id',
onupdate="cascade", ondelete="restrict"))
@declared_attr
def updated_by(cls):
return Column(Integer, ForeignKey('user.user_id',
onupdate="cascade", ondelete="restrict"))
created_at = Column(DateTime, nullable=False, default=dt.now())
updated_at = Column(DateTime, nullable=False, default=dt.now(),
onupdate=dt.now())
class Net(Base, CreatedMixin):
"""Net or subnet."""
cidr = Column(postgresql.CIDR, index = True)
description = Column(UnicodeText())
parent_id = Column(Integer, ForeignKey('net.id'))
parent = relationship("Net", remote_side="Net.id")
def __init__(self, cidr=''):
self.cidr = cidr
def __repr__(self):
return "%s" % self.cidr
Для автозаполнения полей create_by и update_by я использую sqlalchemy.orm.events.MapperEvents
(SQLAlchemy 0.7) следующим образом:
def created_before_insert_listener(mapper, connection, target):
# execute a stored procedure upon INSERT,
# apply the value to the row to be inserted
#target.calculated_value = connection.scalar(
# "select my_special_function(%d)"
# % target.special_number)
target.updated_by = 1
# associate the listener function with CreatedMixin,
# to execute during the "before_insert" hook
event.listen(CreatedMixin, 'before_insert', created_before_insert_listener)
Но после запуска приложения получилось следующееошибка, но не отображается
sqlalchemy.orm.exc.UnmappedClassError: Class 'myapp.model.Net'
Что не так?