欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python Django ORM連表正反操作技巧

 更新時(shí)間:2021年06月13日 12:10:36   作者:磕伴  
這篇文章主要介紹了Django-ORM-連表正反操作,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

一、A表男生,B表女生,C表關(guān)系

1通過(guò)A表查與某個(gè)男生有關(guān)系的所有女生

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

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

思想2:通過(guò)C表跨到A表找到對(duì)應(yīng)男生,然后再跨到B表找到女生

love_list=models.Love.objects.filter(b__name='陳亮')  #這個(gè)是b__跨表查詢
 for i in love_list:
     print(i.g.nick, love_list)    #這個(gè)是按照.類里面的名字查詢

二、A表男生,B表女生,自動(dòng)創(chuàng)建C表ManyToManyField

class Boy(models.Model):
    name = models.CharField(max_length=32)
    m=models.ManyToManyField('Girl')  # 讓其自動(dòng)創(chuàng)建一個(gè)表

通過(guò)boy表查對(duì)應(yīng)的girl

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

通過(guò)girl反查對(duì)應(yīng)的男孩

oss = models.Girl.objects.filter(nick='小貓').first()
a=oss.boy_set.all()  #跨表查詢
for i in a:
     print(i.name)

三、A表男女混合表,B表關(guān)系表

&&&

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

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

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

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

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

#related_query_name 關(guān)聯(lián)的是哪個(gè)ForeignKey
#obj對(duì)象男.girl_set.all() 把這個(gè)名字換成related_query_name的名字
#obj對(duì)象女.boy_set.all() #默認(rèn)表明+_set

#related_name 更簡(jiǎn)單
#obj對(duì)象男.girl.all() 這種方法改名可以直接寫(xiě)b.all()獲取有關(guān)聯(lián)的所有女性表
#obj對(duì)象女.boy.all()

從男女混合表中查到具體人對(duì)應(yīng)所有的有關(guān)系的異性

obj=models.Boy_and_girl.objects.filter(id=3).first() #對(duì)象
if obj.gender==1:
    bb=obj.girls.all()      #根據(jù)對(duì)象反向查找到跟對(duì)象有關(guān)的所有信息(在另外一張表上)
    for i in bb:
        print(i.g.nickname)  #再帶著相關(guān)信息(女孩)回到原來(lái)的表再查詢
else:
    bb = obj.boys.all()
    for i in bb:
        print(i.b.nickname)

四、A表男女混合表(從一張表開(kāi)始)FK自關(guān)聯(lián)

&&&

思路:男女混合表,在同一張表自動(dòng)生成另外一張自己與自己相關(guān)聯(lián)的表(類似于

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()  #以左邊為條件去查,(一共有左(男生)右(女生)兩個(gè)選項(xiàng),從左查為正查,從右查為反查)

for i in girl_list:
       print(i.nickname)

#若是這個(gè)obj是屬于右邊選項(xiàng)的,想要反查左邊的,得用小寫(xiě)表名_set來(lái)進(jìn)行反查比如:

obj. boy_and_girl_set.all()  或者obj.boy.all()

ps:

Django model中的class Meta詳解

以上就是Django-ORM-連表正反操作的詳細(xì)內(nèi)容,更多關(guān)于Django-ORM-連表正反操作的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Python全角與半角之間相互轉(zhuǎn)換的方法總結(jié)

    Python全角與半角之間相互轉(zhuǎn)換的方法總結(jié)

    全角與半角轉(zhuǎn)換在處理漢語(yǔ)語(yǔ)料中會(huì)經(jīng)常出現(xiàn),這里分別說(shuō)明漢字、數(shù)字、字母的unicode編碼范圍,下面這篇文章主要給大家介紹了關(guān)于Python全角與半角之間相互轉(zhuǎn)換的相關(guān)資料,需要的朋友可以參考下
    2022-03-03
  • python使用pandas處理excel文件轉(zhuǎn)為csv文件的方法示例

    python使用pandas處理excel文件轉(zhuǎn)為csv文件的方法示例

    這篇文章主要介紹了python使用pandas處理excel文件轉(zhuǎn)為csv文件的方法示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • python中import reload __import__的區(qū)別詳解

    python中import reload __import__的區(qū)別詳解

    這篇文章主要介紹了python中import reload __import__的區(qū)別詳解,需要的朋友可以參考下
    2017-10-10
  • Python?Pygame繪制直線實(shí)現(xiàn)光線反射效果

    Python?Pygame繪制直線實(shí)現(xiàn)光線反射效果

    這篇文章主要為大家詳細(xì)介紹了如何利用Python?Pygame繪制直線以實(shí)現(xiàn)光線反射效果,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-11-11
  • Python2.7下安裝Scrapy框架步驟教程

    Python2.7下安裝Scrapy框架步驟教程

    本篇文章主要介紹了Python2.7下安裝Scrapy框架步驟教程,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-12-12
  • Python?EasyDict庫(kù)以屬性方式訪問(wèn)字典元素(無(wú)需使用方括號(hào)和鍵)

    Python?EasyDict庫(kù)以屬性方式訪問(wèn)字典元素(無(wú)需使用方括號(hào)和鍵)

    在Python中,字典(dict)是一種常用的數(shù)據(jù)結(jié)構(gòu),用于存儲(chǔ)鍵值對(duì),然而,有時(shí)候我們希望以屬性的方式訪問(wèn)字典中的元素,而無(wú)需使用方括號(hào)和鍵,這就是EasyDict庫(kù)的用武之地,本文將深入介紹EasyDict庫(kù),展示其強(qiáng)大的功能和如何通過(guò)示例代碼更好地利用它
    2023-12-12
  • scrapy爬蟲(chóng):scrapy.FormRequest中formdata參數(shù)詳解

    scrapy爬蟲(chóng):scrapy.FormRequest中formdata參數(shù)詳解

    這篇文章主要介紹了scrapy爬蟲(chóng):scrapy.FormRequest中formdata參數(shù)詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-04-04
  • Python用dilb提取照片上人臉的示例

    Python用dilb提取照片上人臉的示例

    這篇文章主要介紹了Python用dilb提取照片上人臉的示例,幫助大家更好的利用python處理人像,感興趣的朋友可以了解下
    2020-10-10
  • 使用django-guardian實(shí)現(xiàn)django-admin的行級(jí)權(quán)限控制的方法

    使用django-guardian實(shí)現(xiàn)django-admin的行級(jí)權(quán)限控制的方法

    這篇文章主要介紹了使用django-guardian實(shí)現(xiàn)django-admin的行級(jí)權(quán)限控制的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-10-10
  • python文件操作整理匯總

    python文件操作整理匯總

    本文主要記錄了個(gè)人在項(xiàng)目中遇到的一些Python中對(duì)于文件、文件夾的操作需要涉及到的函數(shù)等內(nèi)容,非常的詳盡,有需要的可以參考下
    2014-10-10

最新評(píng)論