编程地带FLASK入门

Flask学习(五)

2018-11-21  本文已影响0人  MA木易YA

这次来整理一下模型中的多对多关系

这里建立了三张表,article, tag 和作为中间表的article_tag


article_tag = db.Table('article_tag',
    db.Column('article_id', db.Integer, db.ForeignKey('article.id'), primary_key=True),
    db.Column('tag_id', db.Integer, db.ForeignKey('tag.id'), primary_key=True),
)


class Article(db.Model):
    __tablename__ = 'article'
    id = db.Column(db.Integer, primary_key=True, autoincrement=True)
    title = db.Column(db.String(10), nullable=False)
    tags = db.relationship('Tag', secondary=article_tag, backref=db.backref('articles'))

class Tag(db.Model):
    __tablename__ = 'tag'
    id = db.Column(db.Integer, primary_key=True, autoincrement=True)
    name = db.Column(db.String(10), nullable=False)

前文提到过,类似tags这样的返回值是一个数组,类似python里的列表,所以可以使用append进行数据添加

@app.route('/')
def index():
    #创建两篇文章
    article1 = Article(title='art1')
    article2 = Article(title='art2')

    #创建两个标签
    tag1 = Tag(name='t1')
    tag2 = Tag(name='t2')

    #给每篇文章添加两个标签
    article1.tags.append(tag1)
    article1.tags.append(tag2)

    article2.tags.append(tag1)
    article2.tags.append(tag2)

    db.session.add(article1)
    db.session.add(article2)

    db.session.add(tag1)
    db.session.add(tag2)

    db.session.commit()



    return 'index'

查看数据内容

image.png

也可以通过文章找到标签

article1 = Article.query.filter(Article.title == 'art1').first()
    tags = article1.tags
    for tag in tags:
        print("%s:%s" %(tag.id, tag.name))
image.png
上一篇下一篇

猜你喜欢

热点阅读