SQLAlchemy支持关系的急切加载,它基本上是一个JOIN声明.但是,如果模型具有两个或更多关系,则它可能是一个非常大的连接.例如,
class Product(Base):
__tablename__ = 'product'
id = Column(Integer, primary_key=True, autoincrement=True)
name = Column(String(255), nullable=False)
orders = relationship('Order', backref='product', cascade='all')
tags = relationship('Tag', secondary=product_tag_map)
class Order(Base):
__tablename__ = 'order'
id = Column(Integer, primary_key=True, autoincrement=True)
date = Column(TIMESTAMP, default=datetime.now())
class Tag(Base):
__tablename__ = 'tag'
id = Column(Integer, primary_key=True, autoincrement=True)
tag_type = Column(String(255), nullable=False)
tag_value = Column(String(255), nullable=False)
q = session.query(Product).join(User.addresses)\
.options(joinedload(Product.orders))\
.options(joinedload(Product.tags)).all()
Run Code Online (Sandbox Code Playgroud)
该查询的性能实在是太差了,因为JOIN中Order和Tag会产生一个巨大的表.但是这里Order并Tag没有关系,所以他们不应该这样JOIN.它应该是两个独立的查询.并且因为会话具有一定程度的缓存,所以我将查询更改为此.
session.query(Product).join(Product.order) \
.options(joinedload(Product.tags)).all()
q …Run Code Online (Sandbox Code Playgroud)