获取所有父表数据,但仅获取满足条件的子表数据
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 子句条件的所有记录