Is there any difference between these two one-to-many relationships?

前端 未结 1 891
庸人自扰
庸人自扰 2021-01-28 17:06
class City(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    cityname = db.Column(db.String(50))
    country_id = db.Column(db.Integer, db.ForeignKey(\'cou         


        
相关标签:
1条回答
  • 2021-01-28 17:46

    Yes, the two methods achieve the same effect of one-to-many relationship (the table construct is identical), the difference being where the relationship is declared.

    My personal preference is to declare the relationship on both models, as it is more explicit and helps with the IDE (auto-complete). You can do this using back_populates in place of backref.

    Takes a string name and has the same meaning as backref, except the complementing property is not created automatically, and instead must be configured explicitly on the other mapper. The complementing property should also indicate back_populates to this relationship to ensure proper functioning.

    class City(db.Model):
        id = db.Column(db.Integer, primary_key=True)
        ...
        country_id = db.Column(db.Integer, db.ForeignKey('country.id'))
        country = db.relationship('Country', back_populates='cities')
    
    class Country(db.Model):
        id = db.Column(db.Integer, primary_key=True)
        ...
        cities = db.relationship('City', back_populates='country')
    
    0 讨论(0)
提交回复
热议问题