python最牛web框架居然是“它”

sqlalchemy中的表關(guān)系

? ? 表之間的關(guān)系存在三種:一對一甜滨、一對多找默、多對多坛芽。而SQLAlchemy中的ORM也可以模擬這三種關(guān)系趾访。因為一對一其實在SQLAlchemy中底層是通過一對多的方式模擬的态秧,所以先來看下一對多的關(guān)系:

1. 一對多:拿User表為例,假如現(xiàn)在要添加一個功能扼鞋,要保存用戶的郵箱帳號申鱼,并且郵箱帳號可以有多個,這時候就必須創(chuàng)建一個新的表云头,用來存儲用戶的郵箱捐友,然后通過user.id來作為外鍵進行引用,先來看下郵箱表的實現(xiàn):

其中盘寡,在User表中添加的addresses字段楚殿,可以通過User.addresses來訪問和這個user相關(guān)的所有address。在Address表中的user字段竿痰,可以通過Address.use來訪問這個user。達到了雙向綁定砌溺。表關(guān)系已經(jīng)建立好以后影涉,接下來就應(yīng)該對其進行操作,先看以下代碼:?

? ? 首先规伐,創(chuàng)建一個用戶蟹倾,然后對這個jack用戶添加兩個郵箱,最后再提交到數(shù)據(jù)庫當中猖闪,可以看到這里操作Address并沒有直接進行保存鲜棠,而是先添加到用戶里面,再保存培慌。

2.. 一對一:一對一其實就是一對多的特殊情況豁陆,從以上的一對多例子中不難發(fā)現(xiàn),一對應(yīng)的是User表吵护,而多對應(yīng)的是Address盒音,也就是說一個User對象有多個Address。因此要將一對多轉(zhuǎn)換成一對一馅而,只要設(shè)置一個User對象對應(yīng)一個Address對象即可祥诽,看以下示例:

從以上例子可以看到,只要在User表中的addresses字段上添加uselist=False就可以達到一對一的效果瓮恭。設(shè)置了一對一的效果后雄坪,就不能添加多個郵箱到user.addresses字段了,只能添加一個:

3. 多對多:多對多需要一個中間表來作為連接屯蹦,同理在sqlalchemy中的orm也需要一個中間表维哈。假如現(xiàn)在有一個Teacher和一個Classes表盯漂,即老師和班級,一個老師可以教多個班級笨农,一個班級有多個老師就缆,是一種典型的多對多的關(guān)系,那么通過sqlalchemy的ORM的實現(xiàn)方式如下:

要創(chuàng)建一個多對多的關(guān)系表谒亦,首先需要一個中間表竭宰,通過Table來創(chuàng)建一個中間表。上例中第一個參數(shù)teacher_classes代表的是中間表的表名份招,第二個參數(shù)是Base的元類切揭,第三個和第四個參數(shù)就是要連接的兩個表,其中Column第一個參數(shù)是表示的是連接表的外鍵名锁摔,第二個參數(shù)表示這個外鍵的類型廓旬,第三個參數(shù)表示要外鍵的表名和字段。 創(chuàng)建完中間表以后谐腰,還需要在兩個表中進行綁定孕豹,比如在Teacher中有一個classes屬性,來綁定Classes表十气,并且通過secondary參數(shù)來連接中間表励背。同理,Classes表連接Teacher表也是如此砸西。定義完類后叶眉,之后就是添加數(shù)據(jù),請看以下示例:

好了芹枷,今天的分享就到這里的衅疙,還有需要完整資料的小伙伴可以私信小編“學(xué)習(xí)”來領(lǐng)取哦sqlalchemy中的表關(guān)系

? ? 表之間的關(guān)系存在三種:一對一、一對多鸳慈、多對多饱溢。而SQLAlchemy中的ORM也可以模擬這三種關(guān)系。因為一對一其實在SQLAlchemy中底層是通過一對多的方式模擬的蝶涩,所以先來看下一對多的關(guān)系:

1. 一對多:拿User表為例理朋,假如現(xiàn)在要添加一個功能,要保存用戶的郵箱帳號绿聘,并且郵箱帳號可以有多個嗽上,這時候就必須創(chuàng)建一個新的表,用來存儲用戶的郵箱熄攘,然后通過user.id來作為外鍵進行引用兽愤,先來看下郵箱表的實現(xiàn):

其中,在User表中添加的addresses字段,可以通過User.addresses來訪問和這個user相關(guān)的所有address浅萧。在Address表中的user字段逐沙,可以通過Address.use來訪問這個user。達到了雙向綁定洼畅。表關(guān)系已經(jīng)建立好以后吩案,接下來就應(yīng)該對其進行操作,先看以下代碼:

? ? 首先帝簇,創(chuàng)建一個用戶徘郭,然后對這個jack用戶添加兩個郵箱,最后再提交到數(shù)據(jù)庫當中丧肴,可以看到這里操作Address并沒有直接進行保存残揉,而是先添加到用戶里面,再保存芋浮。

2.. 一對一:一對一其實就是一對多的特殊情況抱环,從以上的一對多例子中不難發(fā)現(xiàn),一對應(yīng)的是User表纸巷,而多對應(yīng)的是Address镇草,也就是說一個User對象有多個Address。因此要將一對多轉(zhuǎn)換成一對一何暇,只要設(shè)置一個User對象對應(yīng)一個Address對象即可陶夜,看以下示例:

從以上例子可以看到,只要在User表中的addresses字段上添加uselist=False就可以達到一對一的效果裆站。設(shè)置了一對一的效果后,就不能添加多個郵箱到user.addresses字段了黔夭,只能添加一個:

3. 多對多:多對多需要一個中間表來作為連接宏胯,同理在sqlalchemy中的orm也需要一個中間表。假如現(xiàn)在有一個Teacher和一個Classes表本姥,即老師和班級肩袍,一個老師可以教多個班級,一個班級有多個老師婚惫,是一種典型的多對多的關(guān)系氛赐,那么通過sqlalchemy的ORM的實現(xiàn)方式如下:

要創(chuàng)建一個多對多的關(guān)系表,首先需要一個中間表先舷,通過Table來創(chuàng)建一個中間表艰管。上例中第一個參數(shù)teacher_classes代表的是中間表的表名,第二個參數(shù)是Base的元類蒋川,第三個和第四個參數(shù)就是要連接的兩個表牲芋,其中Column第一個參數(shù)是表示的是連接表的外鍵名,第二個參數(shù)表示這個外鍵的類型,第三個參數(shù)表示要外鍵的表名和字段缸浦。 創(chuàng)建完中間表以后夕冲,還需要在兩個表中進行綁定,比如在Teacher中有一個classes屬性裂逐,來綁定Classes表歹鱼,并且通過secondary參數(shù)來連接中間表。同理卜高,Classes表連接Teacher表也是如此弥姻。定義完類后,之后就是添加數(shù)據(jù)篙悯,請看以下示例:

好了蚁阳,今天的分享就到這里的,還有需要完整資料的小伙伴可以私信小編“學(xué)習(xí)”來領(lǐng)取哦

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末鸽照,一起剝皮案震驚了整個濱河市螺捐,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌矮燎,老刑警劉巖定血,帶你破解...
    沈念sama閱讀 212,718評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異诞外,居然都是意外死亡澜沟,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,683評論 3 385
  • 文/潘曉璐 我一進店門峡谊,熙熙樓的掌柜王于貴愁眉苦臉地迎上來茫虽,“玉大人,你說我怎么就攤上這事既们”粑觯” “怎么了?”我有些...
    開封第一講書人閱讀 158,207評論 0 348
  • 文/不壞的土叔 我叫張陵啥纸,是天一觀的道長号杏。 經(jīng)常有香客問我,道長斯棒,這世上最難降的妖魔是什么盾致? 我笑而不...
    開封第一講書人閱讀 56,755評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮荣暮,結(jié)果婚禮上庭惜,老公的妹妹穿的比我還像新娘。我一直安慰自己渠驼,他們只是感情好蜈块,可當我...
    茶點故事閱讀 65,862評論 6 386
  • 文/花漫 我一把揭開白布鉴腻。 她就那樣靜靜地躺著,像睡著了一般百揭。 火紅的嫁衣襯著肌膚如雪爽哎。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 50,050評論 1 291
  • 那天器一,我揣著相機與錄音课锌,去河邊找鬼。 笑死祈秕,一個胖子當著我的面吹牛渺贤,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播请毛,決...
    沈念sama閱讀 39,136評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼志鞍,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了方仿?” 一聲冷哼從身側(cè)響起固棚,我...
    開封第一講書人閱讀 37,882評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎仙蚜,沒想到半個月后此洲,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,330評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡委粉,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,651評論 2 327
  • 正文 我和宋清朗相戀三年呜师,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片贾节。...
    茶點故事閱讀 38,789評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡汁汗,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出栗涂,到底是詐尸還是另有隱情碰酝,我是刑警寧澤,帶...
    沈念sama閱讀 34,477評論 4 333
  • 正文 年R本政府宣布戴差,位于F島的核電站,受9級特大地震影響铛嘱,放射性物質(zhì)發(fā)生泄漏暖释。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 40,135評論 3 317
  • 文/蒙蒙 一墨吓、第九天 我趴在偏房一處隱蔽的房頂上張望球匕。 院中可真熱鬧,春花似錦帖烘、人聲如沸亮曹。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,864評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽照卦。三九已至式矫,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間役耕,已是汗流浹背采转。 一陣腳步聲響...
    開封第一講書人閱讀 32,099評論 1 267
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留瞬痘,地道東北人故慈。 一個月前我還...
    沈念sama閱讀 46,598評論 2 362
  • 正文 我出身青樓,卻偏偏與公主長得像框全,于是被迫代替她去往敵國和親察绷。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,697評論 2 351