首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >hybrid_properties在SQLAlchemy中的优化

hybrid_properties在SQLAlchemy中的优化
EN

Stack Overflow用户
提问于 2016-08-24 09:22:07
回答 1查看 181关注 0票数 0

我有一段工作代码,但是它效率很低,而不是一个带有join的查询。我得到一个初始查询,然后是响应中的每一行查询。

我必须在以下情况下:

代码语言:javascript
复制
class Job(Base, SerializeMixin, JobInterface):
    __tablename__ = 'job_subjobs'

    id = Column(Integer, primary_key=True, autoincrement=True)
    group_id = Column(Integer, ForeignKey("job_groups.id"), nullable=False)

class Crash(Base, SerializeMixin):
    __tablename__ = 'crashes'

    id = Column(Integer, primary_key=True, autoincrement=True)
    job_id = Column(Integer, ForeignKey("job_subjobs.id", ondelete='CASCADE'), nullable=False)

    job = relationship('Job', backref='Crash')

    @hybrid_property
    def job_identifier(self):
        return "{}:{}".format(self.job.group_id, self.job.id)

因此,鉴于以上所述,我对所有Crashes执行一个查询,它将对所有崩溃执行一个选择。当我迭代并请求job_identifier时,它将为每次崩溃执行一个单独的选择。

代码语言:javascript
复制
    self.session.query(Crash).all()

有什么方法可以创建引用不同表的@hybrid_property并让它从一开始就加入并预加载表达式吗?

我试验过@xxx.expression,但没有成功。如果所有这些都失败了,我可以在崩溃表中添加另一个外键,但如果可能的话,我希望避免更改当前的数据结构。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-09-12 13:54:36

最后使用:

代码语言:javascript
复制
jobs = relationship('Job', backref='Crash', lazy='joined')
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39119293

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档