django雙下劃線的具體使用
在 Django 中,雙下劃線(__
)約定通常用于執(zhí)行一些特定的查詢操作,尤其是在使用 Django ORM 進(jìn)行數(shù)據(jù)庫查詢時。這種約定被稱為雙下劃線查詢語法。
雙下劃線查詢語法允許你在查詢中使用類似于 SQL 的語法,以執(zhí)行復(fù)雜的過濾、聯(lián)結(jié)和聚合操作。下面是一些常見的用法:
字段查找:使用雙下劃線可以跨越關(guān)系進(jìn)行字段查找,例如:
Entry.objects.filter(blog__name='example')
這將返回所有 Entry
對象,其關(guān)聯(lián)的 Blog
對象的名稱是 ‘example’。
雙下劃線操作符:在查詢中可以使用一些雙下劃線操作符,例如:
exact
:精確匹配。iexact
:忽略大小寫的精確匹配。contains
:包含。icontains
:忽略大小寫的包含。in
:在某個范圍內(nèi)。gt
:大于。lt
:小于。- 等等…
聚合操作:雙下劃線也可以用于執(zhí)行聚合操作,例如:
from django.db.models import Count Author.objects.annotate(num_books=Count('book'))
這將為每個作者對象添加一個 num_books
屬性,表示該作者擁有的書籍?dāng)?shù)量。
反向關(guān)系查詢:雙下劃線可以在反向關(guān)系上使用,例如:
Blog.objects.filter(entry__headline__contains='Lennon')
這將返回所有博客,其關(guān)聯(lián)的任何條目的標(biāo)題包含 ‘Lennon’。
雙下劃線查詢語法是 Django 中非常強(qiáng)大且常用的特性之一,它使得數(shù)據(jù)庫查詢變得靈活而強(qiáng)大,允許你以簡單的方式執(zhí)行復(fù)雜的查詢。
詳解
當(dāng)你執(zhí)行Entry.objects.filter(blog__name='example')
這樣的查詢時,你實際上是在查詢名為Entry
的模型的對象,但是你想要過濾這些Entry
對象,以便它們關(guān)聯(lián)的Blog
對象的名稱為"example"。
讓我們來詳細(xì)解釋這個查詢:
Entry.objects.filter()
:這是一個查詢集(QuerySet)方法,它允許你過濾模型的對象。Entry
是一個模型類,objects
是默認(rèn)的管理器,filter()
用于過濾查詢集。
blog__name='example'
:在這個過濾器中,blog
是Entry
模型中一個外鍵字段(或者是一個一對一字段),它將Entry
模型與Blog
模型相關(guān)聯(lián)。name
是Blog
模型中的一個字段。blog__name
的含義是從Entry
模型跨越blog
關(guān)系,進(jìn)而查找Blog
模型的name
字段。
blog
是Entry
模型中的外鍵(或一對一)字段,它指向了相關(guān)聯(lián)的Blog
對象。name
是Blog
模型中的一個字段,你想要對這個字段進(jìn)行過濾。__
雙下劃線表示在模型之間進(jìn)行關(guān)聯(lián)查詢。
因此,這個查詢將返回所有Entry
對象,它們關(guān)聯(lián)的Blog
對象的名稱為"example"的條目。
以下是一個簡單的示例模型代碼,包含了兩個模型:Entry
和Blog
。Entry
模型包含了一個外鍵字段指向Blog
模型。
from django.db import models class Blog(models.Model): name = models.CharField(max_length=100) tagline = models.TextField() def __str__(self): return self.name class Entry(models.Model): blog = models.ForeignKey(Blog, on_delete=models.CASCADE) headline = models.CharField(max_length=255) body_text = models.TextField() pub_date = models.DateField() def __str__(self): return self.headline
在這個示例中,Entry
模型有一個名為blog
的外鍵字段,它關(guān)聯(lián)到Blog
模型。這個外鍵字段表示了一個Entry
對象與一個Blog
對象的關(guān)系。每個Entry
對象都關(guān)聯(lián)到一個Blog
對象,因此你可以通過Entry
對象的blog
屬性訪問關(guān)聯(lián)的Blog
對象。
在進(jìn)行查詢時,你可以使用雙下劃線語法來跨越這種關(guān)系,例如:Entry.objects.filter(blog__name='example')
。
到此這篇關(guān)于django 雙下劃線的具體使用的文章就介紹到這了,更多相關(guān)django 雙下劃線內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Pytorch實現(xiàn)LSTM案例總結(jié)學(xué)習(xí)
這篇文章主要介紹了Pytorch實現(xiàn)LSTM案例總結(jié)學(xué)習(xí),文章通過構(gòu)建網(wǎng)絡(luò)層、前向傳播forward()展開主題介紹,需要的小伙吧可以參考一下2022-07-07flask+pymysql實現(xiàn)Web端操作數(shù)據(jù)庫的項目實踐
本文主要介紹了flask+pymysql實現(xiàn)Web端操作數(shù)據(jù)庫的項目實踐,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06python+selenium+Chrome options參數(shù)的使用
這篇文章主要介紹了python+selenium+Chrome options參數(shù)的使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03python調(diào)用另外一個py文件中函數(shù)的具體步驟
這篇文章主要給大家介紹了關(guān)于python調(diào)用另外一個py文件中函數(shù)的具體步驟,要在一個Python文件中調(diào)用其他Python文件中的方法,可以使用Python的模塊導(dǎo)入功能,需要的朋友可以參考下2023-11-11Python?Conda安裝包報錯:PackagesNotFoundError兩種解決方法
這篇文章主要給大家介紹了關(guān)于Python?Conda安裝包報錯:PackagesNotFoundError的兩種解決方法,這通常意味著安裝程序正在尋找的環(huán)境包沒有在 conda 的默認(rèn)通道中找到,文中將解決的辦法介紹的非常詳細(xì),需要的朋友可以參考下2024-06-06