欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

在Django中怎么使用聚合-創(chuàng)新互聯(lián)

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

創(chuàng)新互聯(lián)建站-專(zhuān)業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性?xún)r(jià)比曲松網(wǎng)站開(kāi)發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式曲松網(wǎng)站制作公司更省心,省錢(qián),快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋曲松地區(qū)。費(fèi)用合理售后完善,10余年實(shí)體公司更值得信賴(lài)。

在本文中,我想向您介紹如何在Django中使用聚合,聚合的含義是“內(nèi)容相關(guān)項(xiàng)的集合,以便它們可以顯示或鏈接到”。在Django中,我們使用的情況例如:

用于在Django模型的數(shù)據(jù)庫(kù)表中查找列的“大值”,“最小值”。

用于基于列在數(shù)據(jù)庫(kù)表中查找記錄的“計(jì)數(shù)”。

用于查找一組相似對(duì)象的“平均值”值。

還用于查找列中的值的總和。

在大多數(shù)情況下,我們對(duì)數(shù)據(jù)類(lèi)型為“整數(shù)”,“浮點(diǎn)數(shù)”,“日期”,“日期時(shí)間”等的列使用聚合。

本質(zhì)上,聚合不過(guò)是對(duì)一組行執(zhí)行操作的一種方式。在數(shù)據(jù)庫(kù)中,它們由運(yùn)算符表示為sum,avg等。執(zhí)行這些操作Django在查詢(xún)集中添加了兩個(gè)新方法。

這兩種方法是聚合和注釋。我們也可以說(shuō),在sql中,aggregate是一個(gè)沒(méi)有分組依據(jù)的操作(SUM,AVG,MIN,MAX),而annotate是在rowet_table.id上具有分組依據(jù)的操作。 (除非明確覆蓋)。

讓我們從新建一個(gè)工程開(kāi)始:

#創(chuàng)建工程
django-admin startproject MyProject
#創(chuàng)建應(yīng)用
python manage.py startapp Myapp

加應(yīng)用到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 
]

執(zhí)行migrate命令:

python manage.py migrate

創(chuàng)建管理員用戶(hù):

python manage.py createsuperuser

打開(kāi)Myapp下models.py文件,寫(xiě)入:

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

然后運(yùn)行數(shù)據(jù)庫(kù)遷移命令:

python manage.py makemigrations
python manage.py migrate

注冊(cè)model到admin中,打開(kāi)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)

之后,您需要打開(kāi)管理面板并將一些項(xiàng)目添加到數(shù)據(jù)庫(kù)中。 之后,我們將啟動(dòng)聚合命令。

現(xiàn)在您需要打開(kāi)django shell,因?yàn)槲覀儗jango shell用于我們的聚合命令。

運(yùn)行命令:

python manage.py shell

1、查看總共有多少本書(shū):

In [1]: from MyApp.models import Book
 
In [2]: Book.objects.count()
Out[2]: 8

2、查看某出版社下有多少本書(shū)?

In [5]: Book.objects.filter(publisher__name = 'Second')
Out[5]: <QuerySet [<Book: Python New Book>, <Book: Kotlin Book>]>

3、查看書(shū)的評(píng)價(jià)價(jià)格:

In [6]: from django.db.models import Avg
 
In [7]: Book.objects.all().aggregate(Avg('price'))
Out[7]: {'price__avg': Decimal('121.25')}

4、查看價(jià)格貴的書(shū)價(jià)格:

In [8]: from django.db.models import Max
 
In [9]: Book.objects.all().aggregate(Max('price'))
Out[9]: {'price__max': Decimal('185')}

5、查看價(jià)格最便宜的書(shū)價(jià)格:

In [10]: from django.db.models import Min
 
In [11]: Book.objects.all().aggregate(Min('price'))
Out[11]: {'price__min': Decimal('50')}

6、所有書(shū)價(jià)格匯總:

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中怎么使用聚合”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性?xún)r(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專(zhuān)為企業(yè)上云打造定制,能夠滿(mǎn)足用戶(hù)豐富、多元化的應(yīng)用場(chǎng)景需求。

新聞名稱(chēng):在Django中怎么使用聚合-創(chuàng)新互聯(lián)
鏈接地址:http://chinadenli.net/article36/pcssg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄App開(kāi)發(fā)營(yíng)銷(xiāo)型網(wǎng)站建設(shè)網(wǎng)站制作網(wǎng)站營(yíng)銷(xiāo)云服務(wù)器

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

網(wǎng)站優(yōu)化排名