您好,登錄后才能下訂單哦!
這篇文章主要講解了如何使用django中related_name,內(nèi)容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。
我們從一個簡單的事說起:
吃貨君到水果攤撿漏買了兩種水果,分別是人參果和蟠桃;后來水果攤主冥冥中感覺自己遺失了重寶,似乎和一個100歲的老爺爺有關(guān),翻看自己的收款賬單,當看到吃貨君的賬單時心頭一緊,就是他買走了我的寶貝,我就要看看他買了我的什么寶貝! 店主通過吃貨君的名字找到了他買的水果,發(fā)現(xiàn)竟然有萬年蟠桃以及億年人參過后,嚎啕大哭起來!?。?/p>
吃飯君是走了什么運呢
下面我們根據(jù)上面的小情節(jié)定義兩個模型,分別是買主模型以及水果模型,一個買主對應(yīng)多個水果模型,簡單的一對多模型:
class Buyer(models.Model): name = models.CharField(verbose_name='買主名', max_length=10) Alipay_id = models.CharField(verbose_name='支付寶賬號') age = models.IntegerField(verbose_name='買主年齡',blank = True) class Fruit(models.Model): buyer = models.ForeignKey(Buyer, related_name='buyer_fruit') fruit_name = models.CharField(verbose_name='水果名', max_length=10) weight = models.FloatField(verbose_name='水果重量')
通常,我們要查詢買主買了哪些水果,首先要根據(jù)條件找到買主信息,然后根據(jù)買主信息找到買主所購買的水果,本例中如下:
#首先獲得水果模型中外鍵指向的表中對象: buyer = Buyer.objects.filter(age = 100).first() #然后通過‘_set'方法獲得子表中的數(shù)據(jù): fruits = buyer.fruit_set.all() """ django 默認每個主表的對象都有一個是外鍵的屬性,可以通過它來查詢到所有屬于主表的子表的信息。 這個屬性的名稱默認是以子表的名稱小寫加上_set()來表示,這里我們的主表是buyer,字表是fruit,所以主表外鍵的屬性就是fruit_set """
上面的fruit_set是django為對象buyer默認創(chuàng)建的外鍵的屬性,個人建議采用自定義的方式定義主表的外鍵,這樣使用時更熟悉一些吧!
而related_name就實現(xiàn)這個功能,在字表中定義外鍵時,增加related_name字段指定這個字表在主表中對應(yīng)的外鍵屬性,
如下:
class Fruit(models.Model): buyer = models.ForeignKey(Buyer, related_name='buyer_fruit') """ 主表:buyer 子表:fruit 子表在主表中對應(yīng)的外鍵屬性:related_name='buyer_fruit' """
那么我們就可以通過自定義外鍵的方式找到需要的信息了:
#首先獲得水果模型中外鍵指向的表中對象: buyer = Buyer.objects.filter(age = 100).first() #然后通過子表中自定義的外鍵獲取子表的所有信息: fruits = buyer.buyer_fruit.all()
看完上述內(nèi)容,是不是對如何使用django中related_name有進一步的了解,如果還想學習更多內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。