您好,欢迎访问一九零五行业门户网

python flask 多对多表查询的实例详解

我们在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 多对多表查询的实例详解的详细内容。
其它类似信息

推荐信息