Автоматическое обновление свойств в sqlalchemy

У меня есть модель sqlalchemy, которая настроена следующим образом:

class Entry(Base):
    __tablename__ = 'entries'
    __table__ = Table('entries', Base.metadata,
            Column('id', Integer, primary_key=True, unique=True),
            Column('user_id', Integer, ForeignKey('users.id', onupdate="CASCADE", ondelete="RESTRICT")),
            Column('title', String(128)),
            Column('slug', String(128), index=True),
            Column('url', String(256), index=True),
            Column('entry', Text),
            Column('cached_entry', Text),
            Column('created', DateTime, server_default=text('current_timestamp')),
            Column('modified', DateTime, server_onupdate=text('current_timestamp')),
            Column('pubdate', DateTime),
            )

Что бы я хотел как это когда я update запись , что cached_entry повторно генерируется, cached_entry - это проанализированная версия записи , проанализированная уценкой. В основном я кэширую вывод синтаксического анализа уценки, чтобы мне не приходилось делать это при каждом отображении записи. Я пробовал использовать @hybrid_method , но это, похоже, не сработало, поскольку оно вообще не хранится в базе данных. У меня он работает в Google AppEngine , но я не могу понять, как сделать то же самое с помощью SQLAlchemy.

Я действительно предпочел бы не добавлять функцию к классу, который используется вместо имен в модели, потому что с точки зрения приложения ее сложнее обеспечить, я не хочу случайно что-то упустить.

5
задан X-Istence 21 June 2011 в 08:22
поделиться