如何在Django中使用聚合的實現(xiàn)示例
在本文中,我想向您介紹如何在Django中使用聚合,聚合的含義是“內(nèi)容相關(guān)項的集合,以便它們可以顯示或鏈接到”。在Django中,我們使用的情況例如:
用于在Django模型的數(shù)據(jù)庫表中查找列的“最大值”,“最小值”。
用于基于列在數(shù)據(jù)庫表中查找記錄的“計數(shù)”。
用于查找一組相似對象的“平均值”值。
還用于查找列中的值的總和。
在大多數(shù)情況下,我們對數(shù)據(jù)類型為“整數(shù)”,“浮點數(shù)”,“日期”,“日期時間”等的列使用聚合。
本質(zhì)上,聚合不過是對一組行執(zhí)行操作的一種方式。在數(shù)據(jù)庫中,它們由運算符表示為sum,avg等。執(zhí)行這些操作Django在查詢集中添加了兩個新方法。
這兩種方法是聚合和注釋。我們也可以說,在sql中,aggregate是一個沒有分組依據(jù)的操作(SUM,AVG,MIN,MAX),而annotate是在rowet_table.id上具有分組依據(jù)的操作。 (除非明確覆蓋)。
讓我們從新建一個工程開始:
#創(chuàng)建工程 django-admin startproject MyProject #創(chuàng)建應(yīng)用 python manage.py startapp Myapp
加應(yīng)用到settings.py文件
INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'Myapp' #newly added ]
執(zhí)行migrate命令:
python manage.py migrate
創(chuàng)建管理員用戶:
python manage.py createsuperuser
打開Myapp下models.py文件,寫入:
from django.db import models # Create your models here. class Author(models.Model): name = models.CharField(max_length=50) def __str__(self): return self.name class Publisher(models.Model): name = models.CharField(max_length=50) def __str__(self): return self.name class Book(models.Model): name = models.CharField(max_length=300) price = models.DecimalField(max_digits=10, decimal_places=2) authors = models.ManyToManyField(Author) publisher = models.ForeignKey(Publisher, on_delete=models.CASCADE) def __str__(self): return self.name
然后運行數(shù)據(jù)庫遷移命令:
python manage.py makemigrations python manage.py migrate
注冊model到admin中,打開Myapp下admin.py文件,加入:
from django.contrib import admin from .models import Book, Author, Publisher # Register your models here. admin.site.register(Book) admin.site.register(Author) admin.site.register(Publisher)
之后,您需要打開管理面板并將一些項目添加到數(shù)據(jù)庫中。 之后,我們將啟動聚合命令。
現(xiàn)在您需要打開django shell,因為我們將django shell用于我們的聚合命令。
運行命令:
python manage.py shell
1、查看總共有多少本書:
In [1]: from MyApp.models import Book In [2]: Book.objects.count() Out[2]: 8
2、查看某出版社下有多少本書?
In [5]: Book.objects.filter(publisher__name = 'Second') Out[5]: <QuerySet [<Book: Python New Book>, <Book: Kotlin Book>]>
3、查看書的評價價格:
In [6]: from django.db.models import Avg In [7]: Book.objects.all().aggregate(Avg('price')) Out[7]: {'price__avg': Decimal('121.25')}
4、查看價格最貴的書價格:
In [8]: from django.db.models import Max In [9]: Book.objects.all().aggregate(Max('price')) Out[9]: {'price__max': Decimal('185')}
5、查看價格最便宜的書價格:
In [10]: from django.db.models import Min In [11]: Book.objects.all().aggregate(Min('price')) Out[11]: {'price__min': Decimal('50')}
6、所有書價格匯總:
In [12]: from django.db.models import Sum In [13]: Book.objects.all().aggregate(Min('price')) Out[13]: {'price__min': Decimal('50')}
7、混合使用:
In [5]: Book.objects.aggregate(Avg('price'), Max('price'), Min('price')) Out[5]: {'price__avg': Decimal('121.25'), 'price__max': Decimal('185'), 'price__min': Decimal('50')}
8、annotate使用:
In [9]: from MyApp.models import Publisher In [10]: from django.db.models import Count In [11]: pubs = Publisher.objects.annotate(num_books=Count('book')) In [12]: pubs[0].num_books Out[12]: 3
到此這篇關(guān)于如何在Django中使用聚合的實現(xiàn)示例的文章就介紹到這了,更多相關(guān)Django使用聚合內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
利用Python實現(xiàn)K-Means聚類的方法實例(案例:用戶分類)
k-means是發(fā)現(xiàn)給定數(shù)據(jù)集的k個簇的算法,也就是將數(shù)據(jù)集聚合為k類的算法,下面這篇文章主要給大家介紹了關(guān)于利用Python實現(xiàn)K-Means聚類的相關(guān)資料,需要的朋友可以參考下2022-05-05Python實現(xiàn)Tab自動補全和歷史命令管理的方法
這篇文章主要介紹了Python實現(xiàn)Tab自動補全和歷史命令管理的方法,實例分析了tab自動補全的實現(xiàn)技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-03-03python中的reduce內(nèi)建函數(shù)使用方法指南
python中的reduce內(nèi)建函數(shù)是一個二元操作函數(shù),他用來將一個數(shù)據(jù)集合(鏈表,元組等)中的所有數(shù)據(jù)進行下列操作:用傳給reduce中的函數(shù) func()(必須是一個二元操作函數(shù))先對集合中的第1,2個數(shù)據(jù)進行操作,得到的結(jié)果再與第三個數(shù)據(jù)用func()函數(shù)運算,最后得到一個結(jié)果2014-08-08Python爬蟲實戰(zhàn)之使用Scrapy爬取豆瓣圖片
在用Python的urllib和BeautifulSoup寫過了很多爬蟲之后,本人決定嘗試著名的Python爬蟲框架——Scrapy.本次分享將詳細(xì)講述如何利用Scrapy來下載豆瓣名人圖片,需要的朋友可以參考下2021-06-06Python爬蟲數(shù)據(jù)處理模塊的安裝使用教程
這篇文章主要為大家介紹了Python爬蟲數(shù)據(jù)處理模塊的安裝使用教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-06-06