相关疑难解决方法(0)

Sqlalchemy mixins /和事件监听器

我正在尝试同时处理2件新事物,因此我们非常感谢您在简化和澄清方面的帮助.

from sqlalchemy.ext.declarative import declared_attr
from sqlalchemy import Column, Float, event

class TimeStampMixin(object):

    @declared_attr
    def __tablename__(cls):
        return cls.__name__.lower()

    created = Column(Float)
    modified = Column(Float)
    def __init__(self, created = None,
                       modified = None):
        self.created = created
        self.modified = modified

def create_time(mapper, connection, target):
    target.created = time()

#def modified_time(mapper, connection, target):
#    target.modified = time()

event.listen(TimeStampMixin, 'before_insert', create_time)
#event.listen(TimeStampMixin, 'before_update', modified_time)
Run Code Online (Sandbox Code Playgroud)

所以我想创建一个我可以在任何类中应用的mixin:

class MyClass(TimeStampMixin, Base):
    etc, etc, etc
Run Code Online (Sandbox Code Playgroud)

此类继承在创建时创建时间戳并在更新时创建/修改时间戳的功能.

在导入时我收到此错误:

raise exc.UnmappedClassError(class_)
sqlalchemy.orm.exc.UnmappedClassError: Class 'db.database.TimeStampMixin' is not mapped
Run Code Online (Sandbox Code Playgroud)

aaaand我在这一点上很难过.

python events model sqlalchemy

10
推荐指数
3
解决办法
4251
查看次数

标签 统计

events ×1

model ×1

python ×1

sqlalchemy ×1