欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何在Django中使用聚合的實(shí)現(xiàn)示例

 更新時(shí)間:2020年03月23日 09:02:23   作者:mindg.cn  
這篇文章主要介紹了如何在Django中使用聚合的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

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

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

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

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

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

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

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

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

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

#創(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)建管理員用戶:

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

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

python manage.py makemigrations
python manage.py migrate

注冊(cè)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)

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

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

運(yùn)行命令:

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、查看書的評(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à)格最貴的書價(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à)格最便宜的書價(jià)格:

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

6、所有書價(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

到此這篇關(guān)于如何在Django中使用聚合的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)Django使用聚合內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 利用Python實(shí)現(xiàn)K-Means聚類的方法實(shí)例(案例:用戶分類)

    利用Python實(shí)現(xiàn)K-Means聚類的方法實(shí)例(案例:用戶分類)

    k-means是發(fā)現(xiàn)給定數(shù)據(jù)集的k個(gè)簇的算法,也就是將數(shù)據(jù)集聚合為k類的算法,下面這篇文章主要給大家介紹了關(guān)于利用Python實(shí)現(xiàn)K-Means聚類的相關(guān)資料,需要的朋友可以參考下
    2022-05-05
  • 判斷網(wǎng)頁編碼的方法python版

    判斷網(wǎng)頁編碼的方法python版

    這篇文章主要為大家詳細(xì)介紹了python代碼判斷網(wǎng)頁編碼的方法,感興趣的小伙伴們可以參考一下
    2016-08-08
  • Python中print()函數(shù)的用法詳情

    Python中print()函數(shù)的用法詳情

    這篇文章主要介紹了Python中print()函數(shù)的用法詳情,Python中print()函數(shù)的方法是打印指定的內(nèi)容。在交互環(huán)境中輸入“help(print)”指令,可以顯示print()函數(shù)的使用方法,下面來看看具體的詳細(xì)內(nèi)容吧
    2022-02-02
  • python中字符串的操作方法大全

    python中字符串的操作方法大全

    這篇文章主要給大家介紹了關(guān)于python中字符串操作方法的相關(guān)資料,文中通過示例代碼詳細(xì)介紹了關(guān)于python中字符串的大小寫轉(zhuǎn)換、isXXX判斷、填充、子串搜索、替換、分割、join以及修剪:strip、lstrip和rstrip的相關(guān)內(nèi)容,需要的朋友可以參考下
    2018-06-06
  • Python實(shí)現(xiàn)Tab自動(dòng)補(bǔ)全和歷史命令管理的方法

    Python實(shí)現(xiàn)Tab自動(dòng)補(bǔ)全和歷史命令管理的方法

    這篇文章主要介紹了Python實(shí)現(xiàn)Tab自動(dòng)補(bǔ)全和歷史命令管理的方法,實(shí)例分析了tab自動(dòng)補(bǔ)全的實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-03-03
  • python django入門

    python django入門

    這篇文章主要為大家介紹了python django的入門,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11
  • python中的reduce內(nèi)建函數(shù)使用方法指南

    python中的reduce內(nèi)建函數(shù)使用方法指南

    python中的reduce內(nèi)建函數(shù)是一個(gè)二元操作函數(shù),他用來將一個(gè)數(shù)據(jù)集合(鏈表,元組等)中的所有數(shù)據(jù)進(jìn)行下列操作:用傳給reduce中的函數(shù) func()(必須是一個(gè)二元操作函數(shù))先對(duì)集合中的第1,2個(gè)數(shù)據(jù)進(jìn)行操作,得到的結(jié)果再與第三個(gè)數(shù)據(jù)用func()函數(shù)運(yùn)算,最后得到一個(gè)結(jié)果
    2014-08-08
  • Python爬蟲實(shí)戰(zhàn)之使用Scrapy爬取豆瓣圖片

    Python爬蟲實(shí)戰(zhàn)之使用Scrapy爬取豆瓣圖片

    在用Python的urllib和BeautifulSoup寫過了很多爬蟲之后,本人決定嘗試著名的Python爬蟲框架——Scrapy.本次分享將詳細(xì)講述如何利用Scrapy來下載豆瓣名人圖片,需要的朋友可以參考下
    2021-06-06
  • Python 類的私有屬性和私有方法實(shí)例分析

    Python 類的私有屬性和私有方法實(shí)例分析

    這篇文章主要介紹了Python 類的私有屬性和私有方法,結(jié)合實(shí)例形式分析了Python面向?qū)ο蟪绦蛟O(shè)計(jì)中類的私有屬性與私有方法簡單操作技巧,需要的朋友可以參考下
    2019-09-09
  • Python爬蟲數(shù)據(jù)處理模塊的安裝使用教程

    Python爬蟲數(shù)據(jù)處理模塊的安裝使用教程

    這篇文章主要為大家介紹了Python爬蟲數(shù)據(jù)處理模塊的安裝使用教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06

最新評(píng)論