python flask 多對(duì)多表查詢功能
我們?cè)趂lask的學(xué)習(xí)中,會(huì)難免遇到多對(duì)多表的查詢,今天我也遇到了這個(gè)問(wèn)題。那么我想了好久。也沒(méi)有想到一個(gè)解決的辦法,試了幾種方法,可能是思路的限制我放棄了,后來(lái),我就在網(wǎng)上百度,可是發(fā)現(xiàn)百度出來(lái)的結(jié)果和自己想要的還有一定的差距,那么我根據(jù)百度上得來(lái)的思路,那么我也對(duì)我的數(shù)據(jù)結(jié)構(gòu)進(jìn)行了探索, 下面來(lái)看看我這里怎么來(lái)查詢的,首先給大家看下我寫的數(shù)據(jù)庫(kù)的代碼的片段,這樣,加深理解。
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
這里有三張表,一張呢是文章的列表,另一張呢,是分類表,我們來(lái)想下,一篇文章可能同時(shí)屬于多個(gè)分類,那么一個(gè)分類可能也屬于多個(gè)文章,這么來(lái)說(shuō)想必我們大家都能理解這個(gè)邏輯,那么呢,我第三表來(lái)顯示多對(duì)多關(guān)系的,那么我們接下來(lái)怎么去查詢呢,其實(shí)我現(xiàn)在的需求就是我要找個(gè)一個(gè)分類下面所有的文章吧,
下面來(lái)看看我的代碼
data=Classifa.query.filter_by(name='數(shù)據(jù)庫(kù)').first() data_post=data.posts
這里呢,我直接先從分類找到這個(gè)分類,然后通過(guò)第三表來(lái)查詢屬于這個(gè)分類的文章、其實(shí)呢 這里很簡(jiǎn)單,可能是我當(dāng)時(shí)自己的腦子短路了吧, 不知道怎么想是對(duì)的,現(xiàn)在來(lái)看 其實(shí)還是那么的簡(jiǎn)單,只是當(dāng)時(shí)我忽略了什么。 加油,學(xué)習(xí)前進(jìn)的路上。
- 使用Python & Flask 實(shí)現(xiàn)RESTful Web API的實(shí)例
- Python利用flask sqlalchemy實(shí)現(xiàn)分頁(yè)效果
- python flask實(shí)現(xiàn)分頁(yè)效果
- win系統(tǒng)下為Python3.5安裝flask-mongoengine 庫(kù)
- 使用Python的Flask框架表單插件Flask-WTF實(shí)現(xiàn)Web登錄驗(yàn)證
- Python的Flask框架標(biāo)配模板引擎Jinja2的使用教程
- 深度定制Python的Flask框架開發(fā)環(huán)境的一些技巧總結(jié)
- Flask解決跨域的問(wèn)題示例代碼
相關(guān)文章
Python使用enumerate獲取迭代元素下標(biāo)
這篇文章主要介紹了python使用enumerate獲取迭代元素下標(biāo),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-02-02如何將Yolov5的detect.py修改為可以直接調(diào)用的函數(shù)詳解
YOLOv4還沒(méi)有退熱,YOLOv5已經(jīng)發(fā)布,下面這篇文章主要給大家介紹了關(guān)于如何將Yolov5的detect.py修改為可以直接調(diào)用的函數(shù)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-04-04教你使用Sublime text3搭建Python開發(fā)環(huán)境及常用插件安裝另分享Sublime text3最新激活注冊(cè)碼
這篇文章主要介紹了使用Sublime text 3搭建Python開發(fā)環(huán)境及常用插件安裝,并提供了最新Sublime text 3激活注冊(cè)碼需要的朋友可以參考下2020-11-11Python實(shí)現(xiàn)提取谷歌音樂(lè)搜索結(jié)果的方法
這篇文章主要介紹了Python實(shí)現(xiàn)提取谷歌音樂(lè)搜索結(jié)果的方法,涉及Python針對(duì)谷歌音樂(lè)相關(guān)信息的獲取技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-07-07python2.7實(shí)現(xiàn)郵件發(fā)送功能
這篇文章主要為大家詳細(xì)介紹了python2.7實(shí)現(xiàn)郵件發(fā)送功能包,含文本、附件、正文圖片等,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-12-12Python?Playwright進(jìn)行常見的頁(yè)面交互操作
在使用?Playwright?進(jìn)行?Web?自動(dòng)化時(shí),頁(yè)面交互是核心操作之一,本文將詳細(xì)介紹如何使用?Playwright?進(jìn)行常見的頁(yè)面交互操作,希望對(duì)大家有所幫助2024-10-10