1. 程式人生 > 程式設計 >如何在Django中使用聚合的實現示例

如何在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中使用聚合的實現示例的文章就介紹到這了,更多相關Django使用聚合內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!