获取所有父表数据,但仅获取满足条件的子表数据

Posted

技术标签:

【中文标题】获取所有父表数据,但仅获取满足条件的子表数据【英文标题】:get all parent table data but only data of child which meet condition 【发布时间】:2022-01-04 08:43:53 【问题描述】:

您好,我有两张这样的桌子:

父母是这样的

class Policy(Base):
    """table containing details for Policies"""

    __tablename__ = "UmbrellaPolicy"
    id = Column(Integer, primary_key=True)
    policy_id = Column(Integer, nullable=False, index=True)
    user_defined_name = Column(String(255), nullable=True)

孩子是这样的

class Site(Base):
    __tablename__ = "Site"

    id = Column(Integer, primary_key=True)
    policy_id = Column(Integer, ForeignKey("Policy.id"))
    site_id = Column(String(32), nullable=False, index=True)
    policy = relationship("Policy", backref="sites")

现在我想获取 Policy 表的所有数据,但仅在 site_id = 100 处获取站点表的数据。我将如何在 orm 中做到这一点?我的意思是 sql 炼金术?请指导

目前正在这样做,但它会带来所有政策:我可以限制谁只获得 site_id = 100 的网站

policies = (
            session.query(Policy)
            .join(Site)
            .filter(
                Policy.user_defined_name == 'yes',
            )
            .all()
        )

这会使用 leftjoins 来完成吗?但是我如何在烧瓶中使用它?

【问题讨论】:

【参考方案1】:

试试这个(它更像是一个伪代码),应该返回所需策略的 id:

def get_policies() -> list:
      return [s.policy_id for s in site.all().filter(site_id=100)]

这将返回一个政策对象列表

【讨论】:

没有任何查询解决方案吗?这似乎太贵了

以上是关于获取所有父表数据,但仅获取满足条件的子表数据的主要内容,如果未能解决你的问题,请参考以下文章

获取 TypeError:__init__() 缺少 1 个必需的位置参数:尝试在包含条目的子表之后添加父表时出现“on_delete”

如何将嵌套的子表值与父表行关联并插入子表值对应于php中的父表行

有外键约束的子表插入数据时出现的错误

我需要从 SQL Server 查询中获取前 5 条记录,但要计算满足 where 子句条件的所有记录

查询以获取 table1 中每一行的结果,其中包含 N 个最大记录的子查询,找到满足 table2 中的条件

SQL Join 一对多从满足条件的相同键值组中提取值