亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁技術(shù)文章
文章詳情頁

Django 聚合函數(shù)的具體使用

瀏覽:7日期:2024-09-06 09:00:56
前言

orm模型中的聚合函數(shù)跟MySQL中的聚合函數(shù)作用是一致的,也有像Sum、Avg、Count、Max、Min,接下來我們逐個(gè)介紹

聚合函數(shù)

所有的聚合函數(shù)都是放在django.db.models下面。并且聚合函數(shù)不能夠單獨(dú)的執(zhí)行,聚合函數(shù)是通過aggregate方法來實(shí)現(xiàn)的。在說明聚合函數(shù)的用法的時(shí)候,都是基于以下的模型對(duì)象來實(shí)現(xiàn)的。

class Author(models.Model): '''作者模型''' name = models.CharField(max_length=100) age = models.IntegerField() email = models.EmailField() class Meta: db_table = ’author’ class Publisher(models.Model): '''出版社模型''' name = models.CharField(max_length=300) class Meta: db_table = ’publisher’ class Book(models.Model): '''圖書模型''' name = models.CharField(max_length=300) pages = models.IntegerField() price = models.FloatField() rating = models.FloatField() author = models.ForeignKey(Author,on_delete=models.CASCADE) publisher = models.ForeignKey(Publisher, on_delete=models.CASCADE) class Meta: db_table = ’book’ class BookOrder(models.Model): '''圖書訂單模型''' book = models.ForeignKey('Book',on_delete=models.CASCADE) price = models.FloatField() class Meta: db_table = ’book_order’Avg

Avg:求平均值。比如想要獲取所有圖書的價(jià)格平均值。那么可以使用以下代碼實(shí)現(xiàn)。

from django.db.models import Avg result = Book.objects.aggregate(Avg(’price’)) print(result)

以上的打印結(jié)果是:

{'price__avg':23.0}

其中price__avg的結(jié)構(gòu)是根據(jù)field__avg規(guī)則構(gòu)成的。如果想要修改默認(rèn)的名字,那么可以將Avg賦值給一個(gè)關(guān)鍵字參數(shù)。示例代碼如下:

from django.db.models import Avg result = Book.objects.aggregate(my_avg=Avg(’price’)) print(result)

以上的打印結(jié)果為

{'my_avg':23}

Count

Count:獲取指定的對(duì)象的個(gè)數(shù)。示例代碼如下:

from django.db.models import Count result = Book.objects.aggregate(book_num=Count(’id’))

以上的result將返回Book表中總共有多少本圖書。

Count類中,還有另外一個(gè)參數(shù)叫做distinct,默認(rèn)是等于False,如果是等于True,那么將去掉那些重復(fù)的值。比如要獲取作者表中所有的不重復(fù)的郵箱總共有多少個(gè),那么可以通過以下代碼來實(shí)現(xiàn):

from djang.db.models import Countresult = Author.objects.aggregate(count=Count(’email’,distinct=True))Max和Min

Max和Min:獲取指定對(duì)象的最大值和最小值。比如想要獲取Author表中,最大的年齡和最小的年齡分別是多少。那么可以通過以下代碼來實(shí)現(xiàn):

from django.db.models import Max,Minresult = Author.objects.aggregate(Max(’age’),Min(’age’))

如果最大的年齡是90,最小的年齡是10。那么以上的result將為:

{'age__max':90,'age__min':10}

Sum

Sum:求指定對(duì)象的總和。比如要求圖書的銷售總額。那么可以使用以下代碼實(shí)現(xiàn):

from djang.db.models import Sumresult = Book.objects.annotate(total=Sum('bookorder__price'))

以上的代碼annotate的意思是給Book表在查詢的時(shí)候添加一個(gè)字段叫做total,這個(gè)字段的數(shù)據(jù)來源是從BookOrder模型的price的總和而來。

aggregate和annotate的區(qū)別

相同點(diǎn):這兩個(gè)方法都可以執(zhí)行聚合函數(shù)。

不同點(diǎn):

aggregate返回的是一個(gè)字典,在這個(gè)字典中存儲(chǔ)的是這個(gè)聚合函數(shù)執(zhí)行的結(jié)果。而annotate返回的是一個(gè)QuerySet對(duì)象,并且會(huì)在查找的模型上添加一個(gè)聚合函數(shù)的屬性。 aggregate不會(huì)做分組,而annotate會(huì)使用group by子句進(jìn)行分組,只有調(diào)用了group by子句,才能對(duì)每一條數(shù)據(jù)求聚合函數(shù)的值。F表達(dá)式:

F表達(dá)式: 動(dòng)態(tài)的獲取某個(gè)字段上的值。并且這個(gè)F表達(dá)式,不會(huì)真正的去數(shù)據(jù)庫中查詢數(shù)據(jù),他相當(dāng)于只是起一個(gè)標(biāo)識(shí)的作用。比如想要將原來每本圖書的價(jià)格都在原來的基礎(chǔ)之上增加10元,那么可以使用以下代碼來實(shí)現(xiàn):

from django.db.models import FBook.objects.update(price=F('price')+10) Q表達(dá)式

Q表達(dá)式:使用Q表達(dá)式包裹查詢條件,可以在條件之間進(jìn)行多種操作。與/或非等,從而實(shí)現(xiàn)一些復(fù)雜的查詢操作。例子如下:

查找價(jià)格大于100,并且評(píng)分達(dá)到4.85以上的圖書:

# 不使用Q表達(dá)式的 books = Book.objects.filter(price__gte=100,rating__gte=4.85) # 使用Q表達(dá)式的 books = Book.objects.filter(Q(price__gte=100)&Q(rating__gte=4.85))

查找價(jià)格低于100元,或者評(píng)分低于4分的圖書:

books = Book.objects.filter(Q(price__gte=100)&Q(rating__gte=4.85))

獲取價(jià)格大于100,并且圖書名字中不包含”傳“字的圖書:

books = Book.objects.filter(Q(price__gte=100)&~Q(name__icontains=’傳’))

到此這篇關(guān)于Django 聚合函數(shù)的具體使用的文章就介紹到這了,更多相關(guān)Django 聚合函數(shù)內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Django
相關(guān)文章:
主站蜘蛛池模板: 欧美日韩一级片在线观看 | 手机看片国产日韩 | 亚洲男人的天堂在线 | 91人成亚洲高清在线观看 | 亚洲视频免费 | 成年网在线观看免费观看网址 | 欧美一级毛片俄罗斯 | 亚洲一区精品在线 | 国产高清免费在线 | 91精品国产9l久久久久 | 夜色成人性y | 手机在线精品视频 | 一级在线观看视频 | 欧美日韩精品一区二区三区视频在线 | 欧美第一页草草影院浮力 | 久久综合久久精品 | 国产精品热久久毛片 | 国产免费爱在线观看视频 | 成人午夜在线观看国产 | 四虎免费大片aⅴ入口 | 久久精品视频一区二区三区 | 久久精品大片 | 99草精品视频 | 性做久久久久久免费观看 | 亚洲天堂视频网站 | 成人在线一区二区 | 久草免费小视频 | 亚洲另类激情综合偷自拍图 | 亚洲一区二区三区影院 | 手机看黄av免费网址 | 免费一级在线观看 | 欧美视频不卡 | 国产精品久久久免费视频 | 亚洲日韩精品欧美一区二区一 | 亚洲综合久久综合激情久久 | 日本免费毛片在线高清看 | 久久亚洲精品国产精品777777 | 国产喷水女王在线播放 | 日本不卡不码高清免费观看 | 一级特黄牲大片免费视频 | 国产一二三区精品 |