python flask(多对多表查询)

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python flask(多对多表查询)相关的知识,希望对你有一定的参考价值。

    我们在flask的学习中,会难免遇到多对多表的查询,今天我也遇到了这个问题。那么我想了好久。也没有想到一个解决的办法,试了几种方法,可能是思路的限制我放弃了,后来,我就在网上百度,可是发现百度出来的结果和自己想要的还有一定的差距,那么我根据百度上得来的思路,那么我也对我的数据结构进行了探索, 下面来看看我这里怎么来查询的,首先给大家看下我写的数据库的代码的片段,这样,加深理解。

post_class=db.Table(post_class,
    db.Column(post_id,db.Integer(),db.ForeignKey(posts.id)),
    db.Column(classifa_id,db.Integer(),db.ForeignKey(fenlei.id)))
class Post(db.Model):#文章表
    __tablename__=posts
    id=db.Column(db.Integer,primary_key=True,autoincrement=True)
    title=db.Column(db.String(255),unique=True)
    text=db.Column(db.Text())
    publish_date=db.Column(db.DateTime,default=datetime.datetime.now())
    user_id=db.Column(db.Integer,db.ForeignKey(users.id))
    is_recomment=db.Column(db.Boolean,default=False)
    comments = db.relationship(
        Comment,
        backref=posts,
        lazy=dynamic)
    tag = db.relationship(
        Tag,
        secondary=posts_tags,
        backref=db.backref(posts, lazy=dynamic)
    )
    classname=db.relationship(Classifa,
        secondary=post_class,
        backref=db.backref(posts))
    def __repr__(self):
        return "<Model Post `{}`>".format(self.title)
class Classifa(db.Model):#分类
    __tablename__=fenlei
    id=db.Column(db.Integer(),primary_key=True)
    name=db.Column(db.String(64))
    def __repr__(self):
        return self.name

这里有三张表,一张呢是文章的列表,另一张呢,是分类表,我们来想下,一篇文章可能同时属于多个分类,那么一个分类可能也属于多个文章,这么来说想必我们大家都能理解这个逻辑,那么呢,我第三表来显示多对多关系的,那么我们接下来怎么去查询呢,其实我现在的需求就是我要找个一个分类下面所有的文章吧,

下面来看看我的代码

data=Classifa.query.filter_by(name=数据库).first()
  data_post=data.posts

这里呢,我直接先从分类找到这个分类,然后通过第三表来查询属于这个分类的文章、其实呢 这里很简单,可能是我当时自己的脑子短路了吧, 不知道怎么想是对的,现在来看 其实还是那么的简单,只是当时我忽略了什么。    加油,学习前进的路上。

以上是关于python flask(多对多表查询)的主要内容,如果未能解决你的问题,请参考以下文章

MySQL 基础 -- 多表关系(一对一1对多(多对一)多对多)多表查询(内连接外连接自连接子查询(嵌套查询)联合查询 union)笛卡儿积

Mybatis多表查询(一对多,多对一,多对多)

LINQ to Entities 查询多对多表

Mybatis的多表(多对多)查询

Mybatis 多表实现多对多查询添加操作

用于连接多对多表的 Linq 查询