У меня есть модель 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),
)
Что мне хотелось бы, так это то, что когда я обновляю entry
, cached_entry
регенерируется, cached_entry
является разобранной уценкой версией entry
.По сути, я кеширую вывод парсинга уценки, чтобы мне не приходилось делать это при каждом показе записи.Я попытался использовать @hybrid_method
, но это, похоже, не сработало, поскольку оно вообще не сохраняется в базе данных.У меня работает на Google AppEngine , но я не могу понять, как сделать то же самое с помощью SQLAlchemy.
Я действительно предпочел бы не добавлятьфункция для класса, который используется вместо имен в модели, потому что его сложнее реализовать с точки зрения приложения, я не хочу случайно что-то упустить.