在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

鍍金池/ 問(wèn)答/Python/ flask-sqlalchemy如何使用原生的sql語(yǔ)句然后封裝?

flask-sqlalchemy如何使用原生的sql語(yǔ)句然后封裝?

實(shí)現(xiàn)一個(gè)對(duì)主機(jī)進(jìn)行分組的功能,前臺(tái)提交過(guò)來(lái)的數(shù)據(jù),包含主機(jī)名稱(chēng)、備注信息、主機(jī)ID,flask-sqlalchemy怎么使用原生的sql語(yǔ)句關(guān)聯(lián)表?然后封裝?

回答
編輯回答
愛(ài)是癌

這變化也忒快了吧。連問(wèn)題的題目都變了


這是原題目的回答,多對(duì)多關(guān)系。

這是我設(shè)置的一個(gè)博客文章與tag多對(duì)多關(guān)系的模型,希望對(duì)你有所幫助。

class TagSpaces(db.Model):
    """多對(duì)多關(guān)系表"""
    __tablename__ = 'tag_spaces'
    tag_id = db.Column(db.Integer, db.ForeignKey('tags.id'), primary_key=True)
    article_id = db.Column(db.Integer, db.ForeignKey('articles.id'), primary_key=True)
    timestamp = db.Column(db.DateTime, default=datetime.utcnow)
class Tag(db.Model):
    """tag表"""
    __tablename__ = 'tags'
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(64), unique=True, index=True)
    tagged = db.relationship('TagSpaces',
                             foreign_keys=[TagSpaces.tag_id],
                             backref=db.backref('tagged', lazy='joined'),
                             lazy='dynamic',
                             cascade='all, delete-orphan')

    def __repr__(self):
        return '<Name %r>' % self.name
class Article(db.Model):
    """article 表"""
    __tablename__ = 'articles'
    id = db.Column(db.Integer, primary_key=True)
    title = db.Column(db.String(64), index=True)
    body = db.Column(db.Text)
    
    ......
    ......    
    ......
    
    tags = db.relationship('TagSpaces',
                           foreign_keys=[TagSpaces.article_id],
                           backref=db.backref('tags', lazy='joined'),
                           lazy='dynamic',
                           cascade='all, delete-orphan')

    def tag(self, tag):
    """寫(xiě)文章的時(shí)候,直接往TagSpaces關(guān)聯(lián)表里添加需要關(guān)聯(lián)的 tag 標(biāo)簽"""
        if not self.is_tagging(tag):
            t = TagSpaces(tags=self, tagged=tag)
            db.session.add(t)

    def untag(self, tag):
    """從TagSpaces關(guān)聯(lián)表里刪除相關(guān)標(biāo)簽"""
        f = self.tags.filter_by(tag_id=tag.id).first()
        if f:
            db.session.delete(f)

    def is_tagging(self, tag):
    """判斷相關(guān)標(biāo)簽是否與文章進(jìn)行了關(guān)聯(lián)"""
        return self.tags.filter_by(tag_id=tag.id).first() is not None
    
    @property
    def taggeds(self):
    """以article類(lèi)屬性的形式,返回文章的tag標(biāo)簽實(shí)例"""
        return Tag.query.join(TagSpaces, TagSpaces.tag_id == Tag.id).filter(TagSpaces.article_id == self.id)
    
article = Article.query.get(1) # 查詢(xún)一篇文章,返回一個(gè)實(shí)例對(duì)象
print article.taggeds # 返回該篇文章關(guān)聯(lián)的所有 tag 標(biāo)簽的實(shí)例對(duì)象。
for tag in article.taggeds:
    print tag.name
    # 循環(huán)返回所有的標(biāo)簽的名稱(chēng)

或者,你可以看看我的博客項(xiàng)目 —— https://github.com/eastossifrage/pyblog/blob/master/app/models.py

2018年5月20日 04:14