国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > Python > 正文

python flask 多對(duì)多表查詢功能

2019-11-25 16:03:57
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

我們?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)的路上。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 锦州市| 枣庄市| 昭觉县| 泸溪县| 名山县| 眉山市| 获嘉县| 三门县| 抚州市| 铜鼓县| 高唐县| 都匀市| 高雄县| 张家港市| 神木县| 广西| 贵州省| 渝中区| 开远市| 旌德县| 芮城县| 宝兴县| 巴林右旗| 元氏县| 攀枝花市| 龙州县| 金塔县| 五华县| 正定县| 皮山县| 灵石县| 平罗县| 舞阳县| 三门峡市| 桐梓县| 巴林右旗| 甘孜县| 景谷| 新民市| 西林县| 高安市|