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)查詢的,首先給大家看下我寫(xiě)的數(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框架開(kāi)發(fā)環(huán)境的一些技巧總結(jié)
- Flask解決跨域的問(wèn)題示例代碼
相關(guān)文章
如何利用python將一個(gè)py文件變成一個(gè)軟件詳解
在我們完成一個(gè)Python項(xiàng)目或一個(gè)程序時(shí),希望將Python的py文件打包成在Windows系統(tǒng)下直接可以運(yùn)行的exe程序,下面這篇文章主要給大家介紹了關(guān)于如何利用python將一個(gè)py文件變成一個(gè)軟件的相關(guān)資料,需要的朋友可以參考下2023-04-04
pandas DataFrame 根據(jù)多列的值做判斷,生成新的列值實(shí)例
今天小編就為大家分享一篇pandas DataFrame 根據(jù)多列的值做判斷,生成新的列值實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-05-05
Django實(shí)現(xiàn)翻頁(yè)的示例代碼
翻頁(yè)是經(jīng)常使用的功能,Django提供了翻頁(yè)器。用Django的Paginator類實(shí)現(xiàn),有需要了解Paginator類用法的朋友可參考。希望此文章對(duì)各位有所幫助2021-05-05
python神經(jīng)網(wǎng)絡(luò)Keras實(shí)現(xiàn)LSTM及其參數(shù)量詳解
這篇文章主要為大家介紹了python神經(jīng)網(wǎng)絡(luò)Keras實(shí)現(xiàn)LSTM及其參數(shù)量詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05
Python+OpenCV數(shù)字圖像處理之ROI區(qū)域的提取
ROI區(qū)域又叫感興趣區(qū)域。在機(jī)器視覺(jué)、圖像處理中,從被處理的圖像以方框、圓、橢圓、不規(guī)則多邊形等方式勾勒出需要處理的區(qū)域,稱為感興趣區(qū)域,ROI。本文主要為大家介紹如何通過(guò)Python+OpenCV提取ROI區(qū)域,需要的朋友可以了解一下2021-12-12
Python 使用requests模塊發(fā)送GET和POST請(qǐng)求的實(shí)現(xiàn)代碼
這篇文章主要介紹了Python 使用requests模塊發(fā)送GET和POST請(qǐng)求的實(shí)現(xiàn)代碼,需要的朋友可以參考下2016-09-09
python基于socket模擬實(shí)現(xiàn)ssh遠(yuǎn)程執(zhí)行命令
這篇文章主要介紹了python基于socket模擬實(shí)現(xiàn)ssh遠(yuǎn)程執(zhí)行命令,幫助大家更好的理解和學(xué)習(xí)python,感興趣的朋友可以了解下2020-12-12

