使用一个查询在 SQLAlchemy 中连接多个表
SQLAlchemy 允许通过使用单个查询连接多个表来高效地检索数据。要连接多个表,需要您定义表示数据库中表的类之间的关系。
在您的例子中,您有三个类:User、Document 和 DocumentsPermissions。让我们在这些类之间建立关系:
class User(Base): __tablename__ = 'users' email = Column(String, primary_key=True) name = Column(String) class Document(Base): __tablename__ = "documents" name = Column(String, primary_key=True) author = Column(String, ForeignKey("users.email"), nullable=False) class DocumentsPermissions(Base): __tablename__ = "documents_permissions" readAllowed = Column(Boolean) writeAllowed = Column(Boolean) document = Column(String, ForeignKey("documents.name"), nullable=False)
通过这些关系,您可以使用单个查询检索所需的表:
query = session.query(User, Document, DocumentsPermissions) \ .filter(User.email == Document.author) \ .filter(Document.name == DocumentsPermissions.document) \ .filter(User.email == "[email protected]") \ .all()
此查询连接 User、Document 和 DocumentsPermissions 表根据他们的关系并根据电子邮件过滤结果。最终结果将是包含所有三个表中的数据的元组列表,如您所描述的。通过使用此方法,您可以通过单个数据库查询高效地从多个表中检索数据。
以上是如何在 SQLAlchemy 中通过单个查询高效连接多个表?的详细内容。更多信息请关注PHP中文网其他相关文章!