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)取哦