国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

如何在Django中使用聚合的實現示例

瀏覽:4日期:2024-10-19 13:01:59

在本文中,我想向您介紹如何在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 makemigrationspython manage.py migrate

注冊model到admin中,打開Myapp下admin.py文件,加入:

from django.contrib import adminfrom .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_booksOut[12]: 3

到此這篇關于如何在Django中使用聚合的實現示例的文章就介紹到這了,更多相關Django使用聚合內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Django
相關文章:
主站蜘蛛池模板: 亚洲第一se情网站 | a高清免费毛片久久 | 久草在线视频看看 | 欧美成人免费全部观看天天性色 | 国产日韩欧美久久久 | 99re这里只有精品99 | 亚洲国产日韩女人aaaaaa毛片在线 | 特级一级毛片视频免费观看 | 亚洲性生活视频 | 91精品欧美一区二区三区 | 日韩国产三级 | 亚洲国产毛片aaaaa无费看 | 一个人看的www片免费视频中文 | 黄色影院在线观看视频 | 超薄肉色丝袜精品足j福利 超级乱淫视频aⅴ播放视频 | 波多野结衣在线观看一区 | 免费看成人频视在线视频 | 亚洲七七久久精品中文国产 | 亚洲一级视频在线观看 | 萌白酱香蕉白丝护士服喷浆 | 超清首页 国产 亚洲 丝袜 | 国产精品一区二区久久精品 | 久久亚洲人成国产精品 | 男人女人真曰批视频播放 | 欧美69视频 | 国产精品夜色视频一区二区 | 狠狠se| 亚洲性生活视频 | 色综合天天综合网看在线影院 | 波多野结衣视频免费在线观看 | 成人观看免费大片在线观看 | 一级淫| 欧美特级午夜一区二区三区 | 国产99久久| 欧美一级毛片欧美一级成人毛片 | aaa成人永久在线观看视频 | 欧美刺激午夜性久久久久久久 | 国产乱淫a∨片免费视频 | 特黄毛片 | 成人午夜爽爽爽免费视频 | 亚洲国产精品大秀在线播放 |