Flask-SQLAlchemy插入具有多个外键的记录

时间:2016-06-01 15:22:35

标签: python flask sqlalchemy foreign-keys flask-sqlalchemy

我有3张桌子:

class User(db.Model):
   id = db.Column(db.Integer, primary_key=True)
   name = db.Column(db.String)
   successes = db.relationship('Success', backref='user', lazy='dynamic')

class Success(db.Model):
   id = db.Column(db.Integer, primary_key=True)
   package = db.Column(db.String)
   user_id = db.Column(db.Integer, db.ForeignKey('user.id'))
   trial_id = db.Column(db.Integer, db.ForeignKey('trials.id'))

class Trials(db.Model):
   id = db.Column(db.Integer, primary_key=True)
   description = db.Column(db.String)
   successes = db.relationship('Success', backref='attempt', lazy='dynamic')

我可以使用以下方法在Success和user表中插入数据:

user.successes.extend(success_objects_list)
db.session.add(user)
db.session.add_all(success_objects_list)
db.session.commit()

这会处理外键 user_id

如何在试用表中同时插入数据数据并处理第二个外键 trial_id ??

1 个答案:

答案 0 :(得分:1)

您可以使用trial.successes执行完全相同的操作,它应该可以正常工作。通过扩展user.successes,您可以将Success实例添加到会话中,并将它们与User实例相关联。通过扩展trial.successes,您可以将Success个实例添加到会话并将其与Trials实例相关联,但由于它们已经在会话中,因此它们不会被添加两次