亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

python flask 多對多表查詢功能

 更新時間:2017年06月25日 10:56:06   作者:北漂的雷子  
我們在flask的學(xué)習(xí)中,會難免遇到多對多表的查詢,今天我也遇到了這個問題。下面把我的思路分享到腳本之家平臺,供大家參考

我們在flask的學(xué)習(xí)中,會難免遇到多對多表的查詢,今天我也遇到了這個問題。那么我想了好久。也沒有想到一個解決的辦法,試了幾種方法,可能是思路的限制我放棄了,后來,我就在網(wǎng)上百度,可是發(fā)現(xiàn)百度出來的結(jié)果和自己想要的還有一定的差距,那么我根據(jù)百度上得來的思路,那么我也對我的數(shù)據(jù)結(jié)構(gòu)進行了探索, 下面來看看我這里怎么來查詢的,首先給大家看下我寫的數(shù)據(jù)庫的代碼的片段,這樣,加深理解。

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

這里有三張表,一張呢是文章的列表,另一張呢,是分類表,我們來想下,一篇文章可能同時屬于多個分類,那么一個分類可能也屬于多個文章,這么來說想必我們大家都能理解這個邏輯,那么呢,我第三表來顯示多對多關(guān)系的,那么我們接下來怎么去查詢呢,其實我現(xiàn)在的需求就是我要找個一個分類下面所有的文章吧,

下面來看看我的代碼

data=Classifa.query.filter_by(name='數(shù)據(jù)庫').first()
 data_post=data.posts

這里呢,我直接先從分類找到這個分類,然后通過第三表來查詢屬于這個分類的文章、其實呢 這里很簡單,可能是我當(dāng)時自己的腦子短路了吧, 不知道怎么想是對的,現(xiàn)在來看 其實還是那么的簡單,只是當(dāng)時我忽略了什么。    加油,學(xué)習(xí)前進的路上。

相關(guān)文章

最新評論