我的模型由父级和子级组成,两者之间是一对一的关系:
class Parent(Base):
__tablename__ = 'parent'
id = Column(Integer, primary_key=True)
name = Column(String)
child = relationship("Child", backref="parent", uselist=False, lazy='joined')
class Child(Base):
__tablename__ = 'child'
child_id = Column(Integer, ForeignKey(Parent.id), primary_key=True)
value = Column(Integer)
我的测试数据如下:
q = s.query(Parent)
pd.read_sql(q.statement,s.bind)
id name child_id value
1 a 1 10
2 b 2 20
3 c 3 30
现在我想使用这个查询仅获取具有child.value > 20 的父级:
q = s.query(Parent).filter(Parent.child.value > 20)
但是出现了这个错误:
AttributeError: Neither 'InstrumentedAttribute' object nor 'Comparator' object
associated with Parent.child has an attribute 'value'
当然,我可以直接查询子类,但我的目标是检索父对象。
Parent
对象?” ,我相信我的回答已经解决了这个问题。至于你其他的问题以及它与Quantopian的链接:问题不够清晰 - 哪些工作?哪些不工作?我只能确认,使用多级属性导航(例如Parent.child[.subchild].property
)来访问关系在SQLAlchemy中不起作用。Quantopian的示例也没有显示出相反的情况 -fundamentals
是模块,而不是映射类。 - van