在本教程之后,对于一对多关系,我有一个简单的代码:
class Parent(Base):
__tablename__ = 'parent'
id = Column(Integer, primary_key=True)
children = relationship("Child", back_populates="parent")
class Child(Base):
__tablename__ = 'child'
id = Column(Integer, primary_key=True)
parent_id = Column(Integer, ForeignKey('parent.id'))
parent = relationship("Parent", back_populates="children")
现在,每当我将孩子设置为列表时,问题是填充parent_id
,并将结果提交到数据库中:
# assume I have a session
children = Child(), Child(), Child()
p = Parent(children=children)
session.add(p)
session.commit()
如果此时检查数据库,则尚未填充parent_id
。我想这是有道理的,因为我在任何地方都没有明确定义parent_id,但是有没有办法让孩子获得父母的身份证?
父母接受孩子作为列表,所以:
children = [Child(), Child(), Child()]
...
p = Parent.query.first()
for child in p.children:
print(child.parent_id)