在SQLAlchemy中优化hybrid

在SQLAlchemy中优化hybrid

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

我必须遵循以下方案:

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)


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

    self.session.query(Crash).all()


有什么办法可以创建一个引用另一个表的@hybrid_property并使其从一开始就加入并预加载表达式?

我尝试了@ xxx.expression,但没有成功。如果所有其他方法均失败,则可以在崩溃表中添加另一个外键,但是如果可能的话,我希望避免更改当前数据结构。

最佳答案

最终使用:

jobs = relationship('Job', backref='Crash', lazy='joined')

关于mysql - 在SQLAlchemy中优化hybrid_properties,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/39119293/

10-12 18:46