我有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 ??
答案 0 :(得分:1)
您可以使用trial.successes
执行完全相同的操作,它应该可以正常工作。通过扩展user.successes
,您可以将Success
实例添加到会话中,并将它们与User
实例相关联。通过扩展trial.successes
,您可以将Success
个实例添加到会话并将其与Trials
实例相关联,但由于它们已经在会话中,因此它们不会被添加两次