這篇文章主要介紹在Django中怎么使用聚合,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

在本文中,我想向您介紹如何在Django中使用聚合,聚合的含義是“內容相關項的集合,以便它們可以顯示或鏈接到”。在Django中,我們使用的情況例如:
用于在Django模型的數據庫表中查找列的“大值”,“最小值”。
用于基于列在數據庫表中查找記錄的“計數”。
用于查找一組相似對象的“平均值”值。
還用于查找列中的值的總和。
在大多數情況下,我們對數據類型為“整數”,“浮點數”,“日期”,“日期時間”等的列使用聚合。
本質上,聚合不過是對一組行執行操作的一種方式。在數據庫中,它們由運算符表示為sum,avg等。執行這些操作Django在查詢集中添加了兩個新方法。
這兩種方法是聚合和注釋。我們也可以說,在sql中,aggregate是一個沒有分組依據的操作(SUM,AVG,MIN,MAX),而annotate是在rowet_table.id上具有分組依據的操作。 (除非明確覆蓋)。
讓我們從新建一個工程開始:
#創建工程 django-admin startproject MyProject #創建應用 python manage.py startapp Myapp
加應用到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 ]
執行migrate命令:
python manage.py migrate
創建管理員用戶:
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
然后運行數據庫遷移命令:
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)
之后,您需要打開管理面板并將一些項目添加到數據庫中。 之后,我們將啟動聚合命令。
現在您需要打開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以上是“在Django中怎么使用聚合”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注創新互聯成都網站設計公司行業資訊頻道!
另外有需要云服務器可以了解下創新互聯scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
新聞名稱:在Django中怎么使用聚合-創新互聯
鏈接地址:http://www.yijiale78.com/article36/pcssg.html
成都網站建設公司_創新互聯,為您提供網站收錄、App開發、營銷型網站建設、網站制作、網站營銷、云服務器
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯