难以理解Flask Mega Tutorial中的一些 Flask-SQLAlchemy 内容。这是代码:
followers = db.Table('followers',
db.Column('follower_id', db.Integer, db.ForeignKey('user.id')),
db.Column('followed_id', db.Integer, db.ForeignKey('user.id'))
)
class User(db.Model):
id = db.Column(db.Integer, primary_key = True)
nickname = db.Column(db.String(64), unique = True)
email = db.Column(db.String(120), index = True, unique = True)
role = db.Column(db.SmallInteger, default = ROLE_USER)
posts = db.relationship('Post', backref = 'author', lazy = 'dynamic')
about_me = db.Column(db.String(140))
last_seen = db.Column(db.DateTime)
followed = db.relationship('User',
secondary = followers,
primaryjoin = (followers.c.follower_id == id),
secondaryjoin = (followers.c.followed_id == id),
backref = db.backref('followers', lazy = 'dynamic'),
lazy = 'dynamic')
def follow(self, user):
if not self.is_following(user):
self.followed.append(user)
return self
def unfollow(self, user):
if self.is_following(user):
self.followed.remove(user)
return self
def is_following(self, user):
return self.followed.filter(followers.c.followed_id == user.id).count() > 0
所以我明白,因为这是一种自引用关系,我们需要某种方式让关联表确定表中的哪个用户是关注者,以及表中的哪个用户是被关注的用户。Primaryjoin
并secondaryjoin
做到这一点,但如何?
我不明白的三件事primaryjoin
如下secondaryjoin
:
- 检查平等
primaryjoin
的目的是什么?或者,换句话说,secondaryjoin
如何将s 添加到关联表中?primaryjoin
secondaryjoin
user.id
- 既然两者都
primaryjoin
取secondaryjoin
一个user.id
要求,那user.id
该去哪儿呢? - 在我的关注/取消关注方法中,SQLAlchemy 如何知道自己是关注者,而传入的用户是被关注的用户?
这些问题一直阻碍我进入下一章,因此非常感谢任何答案。