亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

Python Django ORM連表正反操作技巧

瀏覽:2日期:2022-07-28 14:42:56
一、A表男生,B表女生,C表關系

Python Django ORM連表正反操作技巧Python Django ORM連表正反操作技巧Python Django ORM連表正反操作技巧Python Django ORM連表正反操作技巧

1通過A表查與某個男生有關系的所有女生

思想1:在A表中確認男生后,通過反查到C表,獲取相關內容(QuerySet),然后再跨到B表獲取所有女生信息。

obj=models.Boy.objects.filter(name=’陳亮’).first()love_list=obj.love_set.all() #love_set.all()反查相關所有(跨表)for i in love_list: #每個i是一個Love的對象,里面有一個id有一個nick print(i.g.nick) #g是models里面class里面的屬性

思想2:通過C表跨到A表找到對應男生,然后再跨到B表找到女生

love_list=models.Love.objects.filter(b__name=’陳亮’) #這個是b__跨表查詢 for i in love_list: print(i.g.nick, love_list) #這個是按照.類里面的名字查詢二、A表男生,B表女生,自動創建C表ManyToManyField

Python Django ORM連表正反操作技巧Python Django ORM連表正反操作技巧Python Django ORM連表正反操作技巧Python Django ORM連表正反操作技巧

class Boy(models.Model): name = models.CharField(max_length=32) m=models.ManyToManyField(’Girl’) # 讓其自動創建一個表

通過boy表查對應的girl

obj=models.Boy.objects.filter(name=’陳亮’).first()# obj.m.add(2,3) #添加新關系# obj.m.clear() #把跟name=’陳亮‘有關的全部刪除 girl_list=obj.m.all() #直接通過.m就查到女孩相關所有#girl_list = obj.m.filter(二次篩選) for i in girl_list: print(i.id,i.nick)

通過girl反查對應的男孩

oss = models.Girl.objects.filter(nick=’小貓’).first()a=oss.boy_set.all() #跨表查詢for i in a: print(i.name)三、A表男女混合表,B表關系表

Python Django ORM連表正反操作技巧&&&Python Django ORM連表正反操作技巧

Python Django ORM連表正反操作技巧Python Django ORM連表正反操作技巧

思路:男女信息(名字,性別等)都放在一個表,另外一個表(兩個屬性)放一個男生的外鍵(記錄男生id)放一個女生的外鍵(記錄女生的id)

問題:反查的時候需要兩個外鍵不知所措(之前的都是一個外鍵)

解決方法:related_query_name或者related_name(更簡單)

g=models.ForeignKey(’Boy_and_girl’,related_name=’boys’,on_delete=models.CASCADE,null=True)

#以前跨表需要寫上obj.小寫的表名_set.all 比如obj.boy_set.all(),用了**后就不用寫小寫的表名_set了

#related_query_name 關聯的是哪個ForeignKey#obj對象男.girl_set.all() 把這個名字換成related_query_name的名字#obj對象女.boy_set.all() #默認表明+_set

#related_name 更簡單#obj對象男.girl.all() 這種方法改名可以直接寫b.all()獲取有關聯的所有女性表#obj對象女.boy.all()

從男女混合表中查到具體人對應所有的有關系的異性

obj=models.Boy_and_girl.objects.filter(id=3).first() #對象if obj.gender==1: bb=obj.girls.all() #根據對象反向查找到跟對象有關的所有信息(在另外一張表上) for i in bb:print(i.g.nickname) #再帶著相關信息(女孩)回到原來的表再查詢else: bb = obj.boys.all() for i in bb:print(i.b.nickname)四、A表男女混合表(從一張表開始)FK自關聯

Python Django ORM連表正反操作技巧&&&Python Django ORM連表正反操作技巧

思路:男女混合表,在同一張表自動生成另外一張自己與自己相關聯的表(類似于二)

class Boy_and_girl (models.Model): name = models.CharField(max_length=32) m=models.ManyToManyField(’ Boy_and_girl ’,related_name=’boy’)obj=models.Boy. Boy_and_girl.filter(id=1).first() #找的id=1是男生girl_list=obj.m.all() #以左邊為條件去查,(一共有左(男生)右(女生)兩個選項,從左查為正查,從右查為反查)for i in girl_list: print(i.nickname)#若是這個obj是屬于右邊選項的,想要反查左邊的,得用小寫表名_set來進行反查比如:obj. boy_and_girl_set.all() 或者obj.boy.all()

ps:

Django model中的class Meta詳解

以上就是Django-ORM-連表正反操作的詳細內容,更多關于Django-ORM-連表正反操作的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 日韩一级黄色录像 | 国产视频三级 | 九九亚洲 | 国产一级做a爰片在线看 | 亚洲国产情侣一区二区三区 | 日本欧美大码aⅴ在线播放 日本欧美不卡一区二区三区在线 | 狠狠色丁香婷婷久久综合不卡 | 99xxoo视频在线永久免费观看 | 中国免费观看的视频 | a级毛片免费 | 的九一视频入口在线观看 | 狠狠色噜噜狠狠狠狠2022 | 日韩三级一区二区三区 | 中文国产成人精品久久一 | 国产精品高清m3u8在线播放 | 国产精品一页 | 91久久福利国产成人精品 | 欧美日韩精品一区二区三区 | 夜夜夜精品视频免费 | 欧美一级毛片在线看视频 | 久久久福利| 欧美成人午夜不卡在线视频 | 国产一区二区三区波多野吉衣 | 做久爱视频在线观看 | 国产免费啪啪 | 无遮挡一级毛片私人影院 | 国产免费高清国产在线视频 | 欧美日韩亚洲精品一区二区 | 免费人成网站在线播放 | 你懂得在线网址 | 欧美xxxx69tube8护士 | 国产chinesehdxxxx大胸 | 一级黄网 | 1024国产手机视频基地 | 国产亚洲精品观看91在线 | 三级成人影院 | 麻豆资源| 久久久亚洲欧洲日产国码二区 | 千百橹最新亚洲地址在线播放 | 亚洲欧美日韩在线精品一区二区 | 玖玖爱在线播放 |