小编wen*_*ong的帖子

SQLAlchemy渴望加载多个关系

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)

该查询的性能实在是太差了,因为JOINOrderTag会产生一个巨大的表.但是这里OrderTag没有关系,所以他们不应该这样JOIN.它应该是两个独立的查询.并且因为会话具有一定程度的缓存,所以我将查询更改为此.

session.query(Product).join(Product.order) \
    .options(joinedload(Product.tags)).all()

q …
Run Code Online (Sandbox Code Playgroud)

python mysql sql sqlalchemy

7
推荐指数
1
解决办法
3807
查看次数

标签 统计

mysql ×1

python ×1

sql ×1

sqlalchemy ×1