Python Flask
我想要实现这样一个功能,即返回用户关注的所有标签下的所有问题,并按照问题时间顺序排序。
标签(Tag)与问题(Question)是多对多的关系,用户(User)与问题(Question)是一对多的关系
我之前直接用的 db.Table 实现多对多,现在按照狗书将关联表改成了一个 FollowTag 模型,联结查询一直不怎么理解,请问该如何实现这个功能?模型与查询怎么写?感谢!🙏
class FollowTag(db.Model):
tag_id = db.Column(db.Integer, db.ForeignKey('tag.id'),
primary_key=True)
question_id = db.Column(db.Integer, db.ForeignKey('question.id'),
primary_key=True)
create_time = db.Column(db.DateTime, default=datetime.utcnow)
1
BigBrother1024 2019-02-10 17:33:06 +08:00 via Android
FollowTag 表需要 user_id
|
2
gogobody 2019-02-10 19:13:17 +08:00 via Android
instances = db.session.query(Question).join( FollowTag, FollowTag.question_id=Question.id).join(Tag,Tag.id==FollowTag.tag_id).join(User,User.id==Tag.user_id).filter(User.id==查询用户 id)
.....大学学得不好🤣,不知道这样有没有用 |
3
MrAMS OP |