1. 程式人生 > >python flask(多對多表查詢)

python flask(多對多表查詢)

color mat integer ring 網上 uniq 自己的 class 根據

我們在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(多對多表查詢)