實(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)表?然后封裝?
這是我設(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
北大青鳥(niǎo)APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國(guó)IT技能型緊缺人才,是大數(shù)據(jù)專(zhuān)業(yè)的國(guó)家
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國(guó)一站式人才培養(yǎng)平臺(tái)、一站式人才輸送平臺(tái)。2014年4月3日在美國(guó)成功上市,融資1
北大課工場(chǎng)是北京大學(xué)校辦產(chǎn)業(yè)為響應(yīng)國(guó)家深化產(chǎn)教融合/校企合作的政策,積極推進(jìn)“中國(guó)制造2025”,實(shí)現(xiàn)中華民族偉大復(fù)興的升級(jí)產(chǎn)業(yè)鏈。利用北京大學(xué)優(yōu)質(zhì)教育資源及背
博為峰,中國(guó)職業(yè)人才培訓(xùn)領(lǐng)域的先行者
曾工作于聯(lián)想擔(dān)任系統(tǒng)開(kāi)發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項(xiàng)目經(jīng)理從事移動(dòng)互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
浪潮集團(tuán)項(xiàng)目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺(tái)面向?qū)ο箝_(kāi)發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫(kù),具有快速界面開(kāi)發(fā)的能力,對(duì)瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁(yè)制作和網(wǎng)頁(yè)游戲開(kāi)發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開(kāi)發(fā)經(jīng)驗(yàn)。曾經(jīng)歷任德國(guó)Software AG 技術(shù)顧問(wèn),美國(guó)Dachieve 系統(tǒng)架構(gòu)師,美國(guó)AngelEngineers Inc. 系統(tǒng)架構(gòu)師。