python – 自动更新sqlalchemy中的属性
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了python – 自动更新sqlalchemy中的属性,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1785字,纯文字阅读大概需要3分钟。
内容图文
![python – 自动更新sqlalchemy中的属性](/upload/InfoBanner/zyjiaocheng/912/eecb83c5da844dcfaf40c2c73f4cf35a.jpg)
我有一个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),
)
我想要的是,当我更新条目时重新生成cached_entry时,cached_entry是markdown解析的条目版本.基本上我正在缓存markdown解析的输出,这样我就不必在每次显示条目时都这样做.我已经尝试使用@hybrid_method但是这似乎没有用,因为它根本没有存储在数据库中.我已经got it working on Google AppEngine了,但我似乎无法弄清楚如何使用SQLAlchemy做同样的事情.
我真的不希望不必将函数添加到使用的类而不是模型中的名称,因为从应用程序的角度来看它更难以强制执行,我不想意外遗漏某些东西.
解决方法:
@hybrid_descriptor当然使用http://www.sqlalchemy.org/docs/orm/mapper_config.html#using-descriptors中描述的形式.您可以分配到数据库映射属性,您可以使用其他名称进行映射 – 因为您使用的是__table__,您可以使用以下形式:
class Entry(Base):
__table__ = ...
_entry = __table__.c.entry
@hybrid_property
def entry(self):
return self._entry
@entry.setter
def entry(self, value):
self._entry = value
self.cached_entry = markdown(value)
另一种方法是使用before_insert和before_update事件在刷新时填充列 – 这是一种简单的方法,但缺点是必须等待flush()才能发生.
我认为“现场”最快的方法是使用@validates:
from sqlalchemy.orm import validates
class Entry(Base):
__table__ = ...
@validates('entry')
def _set_entry(self, key, value):
self.cached_entry = markdown(value)
return value
内容总结
以上是互联网集市为您收集整理的python – 自动更新sqlalchemy中的属性全部内容,希望文章能够帮你解决python – 自动更新sqlalchemy中的属性所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。