flask-sqlalchemy使用(基礎(chǔ)操作篇)

創(chuàng)建數(shù)據(jù)庫.png

一    連接數(shù)據(jù)庫
在Flask-SQLAlchemy 中睹栖,數(shù)據(jù)庫被指定為URL,MySQL的數(shù)據(jù)庫引擎的URL格式如下:
mysql://username:password@hostname/database
hostname 托管MySQL服務(wù)的服務(wù)器抹镊,也可以是遠(yuǎn)程服務(wù)器
database 要使用的數(shù)據(jù)庫名
username password 使用數(shù)據(jù)庫的用戶憑證

SQLALCHEMY_COMMIT_ON_TEARDOWN可以設(shè)置為True舟误,
來啟用自動提交數(shù)據(jù)庫更改在每個請求中
由SQLAlchemy實(shí)例化的db對象表示數(shù)據(jù)庫且提供訪問Flask-SQLAlchemy的所有功能

二    定義數(shù)據(jù)庫
tablename類變量定義數(shù)據(jù)庫中表的名稱崔泵。
如果tablename缺省,F(xiàn)lask-SQLAlchemy會指定默認(rèn)的表名嫉髓,但是這些缺省名稱不遵守使用復(fù)數(shù)命名的約定倘零,所以最好是顯式命名表名。
其余的變量是模型的屬性幻梯,被定義為db.Column類的實(shí)例

傳給db.Column構(gòu)造函數(shù)的第一個參數(shù)是數(shù)據(jù)庫列的類型也就是模型屬性的數(shù)據(jù)類型
見flask-sqlalchemy使用(基礎(chǔ)知識)
db.Column剩余的參數(shù)為每個屬性指定了配置選項(xiàng)
見flask-sqlalchemy使用(基礎(chǔ)知識)

模型包含了repr()方法來給它們顯示一個可讀字符串兜畸,雖然不是完全必要,不過用于調(diào)試和測試還是很不錯的

三    建立外鍵
添加給User模型的role_id列被定義為外鍵碘梢,且建立關(guān)系咬摇。
db.ForeignKey()的參數(shù)roles.id指定的列應(yīng)該理解為在roles表的行中持有id值的列

添加到Role模型的users屬性表現(xiàn)了關(guān)系的面向?qū)ο蟮挠^點(diǎn)。給定Role類的實(shí)例煞躬,
users屬性會返回一組連接到該角色的用戶肛鹏。指定給db.relationship()的第一個參數(shù)表明模型中關(guān)系的另一邊。如果類還未定義恩沛,這個模型可以作為字符串提供在扰。

ForeignKey類的column接收三種類型的參數(shù),
一種是“模型名.屬性名”雷客;
一種是“表名.列名”芒珠,
最后一種沒看明白,下次試著用一下搅裙。

db.relationship()的backref參數(shù)通過給User模型增加role屬性來定義反向關(guān)系皱卓。這個屬性可以替代role_id訪問Role模型,是作為對象而不是外鍵部逮。

大多數(shù)情況下db.relationship()可以定位自己的外鍵關(guān)系娜汁,但是有時候不能確定哪個列被用作外鍵。例如甥啄,如果User模型有兩個或更多列被定義為Role的外鍵存炮,SQLAlchemy將不知道使用兩個中的哪一個。每當(dāng)外鍵配置模棱兩可的時候,就必須使用額外參數(shù)db.relationship()穆桂。表格5-4列出一些常用配置選項(xiàng)用于定義關(guān)系宫盔。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市享完,隨后出現(xiàn)的幾起案子灼芭,更是在濱河造成了極大的恐慌,老刑警劉巖般又,帶你破解...
    沈念sama閱讀 206,723評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件彼绷,死亡現(xiàn)場離奇詭異,居然都是意外死亡茴迁,警方通過查閱死者的電腦和手機(jī)寄悯,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,485評論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來堕义,“玉大人猜旬,你說我怎么就攤上這事【肼簦” “怎么了洒擦?”我有些...
    開封第一講書人閱讀 152,998評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長怕膛。 經(jīng)常有香客問我熟嫩,道長,這世上最難降的妖魔是什么褐捻? 我笑而不...
    開封第一講書人閱讀 55,323評論 1 279
  • 正文 為了忘掉前任掸茅,我火速辦了婚禮,結(jié)果婚禮上舍扰,老公的妹妹穿的比我還像新娘倦蚪。我一直安慰自己,他們只是感情好边苹,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,355評論 5 374
  • 文/花漫 我一把揭開白布陵且。 她就那樣靜靜地躺著,像睡著了一般个束。 火紅的嫁衣襯著肌膚如雪慕购。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,079評論 1 285
  • 那天茬底,我揣著相機(jī)與錄音沪悲,去河邊找鬼。 笑死阱表,一個胖子當(dāng)著我的面吹牛殿如,可吹牛的內(nèi)容都是我干的贡珊。 我是一名探鬼主播,決...
    沈念sama閱讀 38,389評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼涉馁,長吁一口氣:“原來是場噩夢啊……” “哼门岔!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起烤送,我...
    開封第一講書人閱讀 37,019評論 0 259
  • 序言:老撾萬榮一對情侶失蹤寒随,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后帮坚,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體妻往,經(jīng)...
    沈念sama閱讀 43,519評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,971評論 2 325
  • 正文 我和宋清朗相戀三年试和,在試婚紗的時候發(fā)現(xiàn)自己被綠了讯泣。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,100評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡阅悍,死狀恐怖判帮,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情溉箕,我是刑警寧澤,帶...
    沈念sama閱讀 33,738評論 4 324
  • 正文 年R本政府宣布悦昵,位于F島的核電站肴茄,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏但指。R本人自食惡果不足惜寡痰,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,293評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望棋凳。 院中可真熱鬧拦坠,春花似錦、人聲如沸剩岳。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,289評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽拍棕。三九已至晓铆,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間绰播,已是汗流浹背骄噪。 一陣腳步聲響...
    開封第一講書人閱讀 31,517評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留蠢箩,地道東北人链蕊。 一個月前我還...
    沈念sama閱讀 45,547評論 2 354
  • 正文 我出身青樓事甜,卻偏偏與公主長得像,于是被迫代替她去往敵國和親滔韵。 傳聞我的和親對象是個殘疾皇子逻谦,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,834評論 2 345

推薦閱讀更多精彩內(nèi)容