日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

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

瀏覽:25日期: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
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
97人人精品| 欧美成人一二区| 国产中文在线播放| 亚洲我射av| 亚洲成人精品| 午夜av成人| 久久av免费| 亚洲另类av| 亚洲欧美日韩视频二区| 国产精品黑丝在线播放| 国产精品99精品一区二区三区∴ | 亚洲天堂成人| 国产成人久久精品一区二区三区| 国产精品chinese| 国产极品模特精品一二| 国产乱子精品一区二区在线观看| 日韩一二三区在线观看| 亚洲精品无吗| 欧美丝袜一区| 欧美日韩四区| 综合激情五月婷婷| 日本a级不卡| 国产精品夜夜夜| 国产精品毛片久久| 亚洲播播91| 日韩午夜一区| 欧美日本三区| 97国产成人高清在线观看| 久久婷婷一区| 美女黄网久久| 国产欧美一区二区三区国产幕精品| 国产欧美日韩精品高清二区综合区| 国产精品任我爽爆在线播放| 日韩在线网址| 精品国产18久久久久久二百| 久久蜜桃av| 五月亚洲婷婷 | 精品国产乱码| 国产韩日影视精品| 91p九色成人| 丁香六月综合| 天堂va蜜桃一区二区三区| 欧美成人aaa| 欧美日韩国产一区二区三区不卡 | 久久这里只有精品一区二区| 成人亚洲一区二区| 久久免费影院| 国产麻豆一区二区三区| 国产精品三p一区二区| 久久激情中文| 精品少妇av| 免费不卡中文字幕在线| 欧美精品中文| 国产日韩中文在线中文字幕| 欧美成a人免费观看久久| 少妇精品久久久一区二区| 91tv亚洲精品香蕉国产一区| 日本v片在线高清不卡在线观看| 最新中文字幕在线播放 | 欧美一区久久| 日韩视频一区| 捆绑调教日本一区二区三区| 日韩国产在线一| 成人精品国产亚洲| 欧美午夜三级| 色综合视频一区二区三区日韩| 四虎8848精品成人免费网站| 久久亚洲成人| 午夜欧美理论片| 精品女同一区二区三区在线观看| 蜜桃视频在线观看一区| 日韩精品免费一区二区在线观看| 国产在线不卡一区二区三区| 国产乱码精品一区二区三区四区 | 免费在线视频一区| 亚洲一级高清| 久久久成人网| 国产伊人久久| 国产一区二区亚洲| 久久精品国产一区二区| 日本va欧美va精品| 日韩一区精品| 日韩一区二区久久| 亚洲电影在线| 亚洲性视频h| 91久久久久| 亚洲精品日韩久久| 亚洲一区二区动漫| 黄色亚洲大片免费在线观看| 亚洲天堂久久| 9久re热视频在线精品| 欧美日韩少妇| 99免费精品| 亚洲一级影院| 三级在线观看一区二区| 男人天堂欧美日韩| 黑丝一区二区三区| 亚洲精品在线观看91| | 国产在线不卡一区二区三区| 亚洲一区欧美激情| 91久久视频| 国产亚洲一级| 视频一区二区不卡| 蜜臀国产一区二区三区在线播放| 日韩中文字幕无砖| 久久伊人国产| 国产精品一卡| 久久国产日韩欧美精品| 在线手机中文字幕| 亚洲男人在线| 国产精品xx| 蜜臀va亚洲va欧美va天堂| 亚洲精品国模| 国产精品最新自拍| 日韩欧美自拍| 亚洲欧洲美洲国产香蕉| 综合激情一区| 超碰超碰人人人人精品| 亚洲欧美日本国产| 免费成人网www| 红杏一区二区三区| 亚洲免费毛片| 日韩成人亚洲| 亚洲2区在线| 蜜臀久久精品| 亚洲2区在线| 欧美日韩水蜜桃| 日本中文字幕视频一区| 国产精久久一区二区| 国产99精品| 粉嫩av一区二区三区四区五区 | 国产一区不卡| 深夜福利视频一区二区| 日本视频中文字幕一区二区三区| 亚洲成人三区| 手机在线电影一区| 日韩区欧美区| 免费一区二区视频| 亚洲午夜精品久久久久久app| 国产日韩在线观看视频| 久久av在线| 国产一区二区三区久久久久久久久| 中文字幕亚洲影视| 亚洲手机在线| 日韩中文在线电影| 国产成人久久精品麻豆二区| 日韩二区三区四区| 黑丝美女一区二区| 蜜桃精品在线| 高清一区二区三区av| 91伊人久久| 亚洲日本三级| 丝袜美腿亚洲一区| aⅴ色国产欧美| 久久精品卡一| 久久婷婷亚洲| 久久久久亚洲精品中文字幕| 18国产精品| 国产精品视频一区二区三区四蜜臂 | 日本精品一区二区三区在线观看视频| 精品一区三区| 久久网站免费观看| 欧美一区二区三区高清视频| 国产国产精品| 亚洲精品一级二级| 深夜视频一区二区| 1000部精品久久久久久久久| 日韩在线不卡| 久久精品青草| 视频一区二区欧美| 欧美亚洲三级| 亚洲www啪成人一区二区| 99久久久久| 蜜臀久久99精品久久久久宅男| 综合激情一区| 国产三级精品三级在线观看国产| 天使萌一区二区三区免费观看| 精品久久久久久久| 日本麻豆一区二区三区视频| 日韩福利视频导航| 92国产精品| 亚洲日本国产| 国产黄色一区| 欧美69视频| 国产亚洲一卡2卡3卡4卡新区| 国产va免费精品观看精品视频| 精品91久久久久| 你懂的亚洲视频| 99xxxx成人网| 国内精品美女在线观看| 免费高清在线一区| 日本伊人久久| 老司机精品在线| 国产高清久久| 福利片在线一区二区| 亚洲欧美专区| 国产精品欧美三级在线观看| 成年男女免费视频网站不卡| 在线精品视频一区|