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

