Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/maven/5.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python SQLAlchemy:单向关系,相关子查询_Python_Sqlalchemy - Fatal编程技术网

Python SQLAlchemy:单向关系,相关子查询

Python SQLAlchemy:单向关系,相关子查询,python,sqlalchemy,Python,Sqlalchemy,提前感谢你的帮助 我有两个实体,人类和黑猩猩。每个都有一个度量集合,其中可以包含度量块的子类,例如CompletedBloodCount(带有白细胞、红细胞、血小板字段) 所以我的对象模型看起来像(请原谅ASCII艺术): 所以人类知道它的度量块,但度量块不知道它的人类或黑猩猩 我想在SQLAlchemy中编写一个查询,以查找特定人类的所有完整血液计数。在SQL中,我可以编写如下内容: SELECT cbc.id FROM complete_blood_count cbc WHERE EXIST

提前感谢你的帮助

我有两个实体,人类和黑猩猩。每个都有一个度量集合,其中可以包含度量块的子类,例如CompletedBloodCount(带有白细胞、红细胞、血小板字段)

所以我的对象模型看起来像(请原谅ASCII艺术):

所以人类知道它的度量块,但度量块不知道它的人类或黑猩猩

我想在SQLAlchemy中编写一个查询,以查找特定人类的所有完整血液计数。在SQL中,我可以编写如下内容:

SELECT cbc.id
FROM complete_blood_count cbc
WHERE EXISTS (
   SELECT 1
   FROM human h
       INNER JOIN human_to_metric_block h_to_m on h.id = h_to_m.human_id
   WHERE
       h_to_m.metric_block_id = cbc.id
)
我正在努力用SQLAlchemy写这篇文章。我相信correlate()、any()或别名连接可能会有所帮助,但MetricBlock不知道它的人类或黑猩猩这一事实对我来说是个绊脚石

有人对如何编写这个查询有什么建议吗?或者,是否有其他策略可以更好地使用SQLAlchemy定义模型

谢谢你的帮助

Python 2.6
SQLAlchemy 0.7.4
Oracle 11g
编辑:

HumanToMetricBlock定义为:

humanToMetricBlock = Table(
    "human_to_metric_block",
    metadata,
    Column("human_id", Integer, ForeignKey("human.id"),
    Column("metric_block_id", Integer, ForeginKey("metric_block.id")
)

每个灵长类动物都应该有一个唯一的ID,不管它们是什么类型的灵长类动物。我不确定为什么每一组属性(MB、CBC、CC)都是独立的表,但我假设它们有不止一个维度(灵长类),比如时间,否则我只会有一个巨大的表

因此,我将以以下方式构造此问题: 创建一个父对象灵长类动物,并从中衍生出人类和黑猩猩。本例使用的是单表继承,但您可能希望基于它们的属性使用联接表继承

class Primate(Base):
    __tablename__ = 'primate'
    id = Column(Integer, primary_key=True)
    genus = Column(String)
    ...attributes all primates have...
    __mapper_args__ = {'polymorphic_on': genus, 'polymorphic_identity': 'primate'}

class Chimp(Primate):
    __mapper_args__ = {'polymorphic_identity': 'chimp'}
    ...attributes...

class Human(Primate):
    __mapper_args__ = {'polymorphic_identity': 'human'}
    ...attributes...

class MetricBlock(Base):
    id = ...
然后创建单个多对多表(可以改用关联代理):

然后我将这样构造查询(注意on子句不是必需的,因为SQLAlchemy可以自动推断关系,因为没有歧义):

如果要按primate类型筛选,请加入primate表并筛选:

query = query.join(Primate, Primate.id == PrimateToMetricBlock.primate_id).\
    filter(Primate.genus == 'human')
否则,如果您知道灵长类的ID(primate_ID),则不需要额外的连接:

query = query.filter(PrimateToMetricBlock.primate_id == primate_id)
如果仅检索一个对象,请使用以下命令结束查询:

return query.first()
否则:

return query.all()

这样构建模型应该可以消除任何混淆,并使一切变得更简单。如果我遗漏了什么,请告诉我。

嗨,乔纳森,谢谢你的快速回复。我用我对多对多联接表的模型定义编辑了这篇文章,不知您能否根据映射来澄清您的文章?我不知道我可以参考这张表。再次感谢。换一种方式问,有没有一种方法可以只使用human.metrics?我有一个人或者一只黑猩猩,我想要CBC的,我想我需要用python查找连接表。我很抱歉没有在帖子中更好地问这个问题;我的问题和你的函数名假设只有人类。啊,我想我找到了一个更好的方法来解决这个问题。让我编辑一下答案。
query = query.join(Primate, Primate.id == PrimateToMetricBlock.primate_id).\
    filter(Primate.genus == 'human')
query = query.filter(PrimateToMetricBlock.primate_id == primate_id)
return query.first()
return query.all()