91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

在Django中怎么使用聚合

發布時間:2021-02-01 10:54:45 來源:億速云 閱讀:161 作者:小新 欄目:開發技術

這篇文章主要介紹在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中怎么使用聚合”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

米脂县| 阳朔县| 克什克腾旗| 错那县| 景洪市| 甘洛县| 元氏县| 林西县| 东台市| 大安市| 曲松县| 建水县| 合水县| 齐齐哈尔市| 石泉县| 六安市| 岢岚县| 通海县| 罗山县| 昌乐县| 阳原县| 昭通市| 芜湖县| 从化市| 万山特区| 绥棱县| 亚东县| 湖口县| 兴仁县| 朝阳县| 孝昌县| 荥经县| 弥勒县| 康马县| 平利县| 丹寨县| 鹿邑县| 新沂市| 安庆市| 耿马| 琼海市|