电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

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

瀏覽:5日期: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
相關文章:
主站蜘蛛池模板: 铸钢件厂家-铸钢齿轮-减速机厂家-淄博凯振机械有限公司 | 河南不锈钢水箱_地埋水箱_镀锌板水箱_消防水箱厂家-河南联固供水设备有限公司 | 薪动-人力资源公司-灵活用工薪资代发-费用结算-残保金优化-北京秒付科技有限公司 | 高压无油空压机_无油水润滑空压机_水润滑无油螺杆空压机_无油空压机厂家-科普柯超滤(广东)节能科技有限公司 | 东莞海恒试验仪器设备有限公司| 吨袋包装机|吨包秤|吨包机|集装袋包装机-烟台华恩科技 | 武汉高温老化房,恒温恒湿试验箱,冷热冲击试验箱-武汉安德信检测设备有限公司 | 杭州火蝠电商_京东代运营_拼多多全托管代运营【天猫代运营】 | 冷藏车厂家|冷藏车价格|小型冷藏车|散装饲料车厂家|程力专用汽车股份有限公司销售十二分公司 | 电子厂招聘_工厂招聘_普工招聘_小时工招聘信息平台-众立方招工网 | 真石漆,山东真石漆,真石漆厂家,真石漆价格-山东新佳涂料有限公司 | 斗式提升机,斗式提升机厂家-淄博宏建机械有限公司 | 圣才学习网-考研考证学习平台,提供万种考研考证电子书、题库、视频课程等考试资料 | 科昊仪器超纯水机系统-可成气相液氮罐-美菱超低温冰箱-西安昊兴生物科技有限公司 | BOE画框屏-触摸一体机-触控查询一体机-触摸屏一体机价格-厂家直销-触发电子 | 净化板-洁净板-净化板价格-净化板生产厂家-山东鸿星新材料科技股份有限公司 | 粘度计维修,在线粘度计,二手博勒飞粘度计维修|收购-天津市祥睿科技有限公司 | 灰板纸、灰底白、硬纸板等纸品生产商-金泊纸业 | 西门子代理商_西门子变频器总代理-翰粤百科| 家乐事净水器官网-净水器厂家「官方」 | 杭州中央空调维修_冷却塔/新风机柜/热水器/锅炉除垢清洗_除垢剂_风机盘管_冷凝器清洗-杭州亿诺能源有限公司 | 黑龙江京科脑康医院-哈尔滨精神病医院哪家好_哈尔滨精神科医院排名_黑龙江精神心理病专科医院 | 高空重型升降平台_高空液压举升平台_高空作业平台_移动式升降机-河南华鹰机械设备有限公司 | 包装机_厂家_价格-山东包装机有限公司| 仓储货架_南京货架_钢制托盘_仓储笼_隔离网_环球零件盒_诺力液压车_货架-南京一品仓储设备制造公司 | 高低温万能试验机-复合材料万能试验机-馥勒仪器 | 植筋胶-粘钢胶-碳纤维布-碳纤维板-环氧砂浆-加固材料生产厂家-上海巧力建筑科技有限公司 | 塑胶跑道_学校塑胶跑道_塑胶球场_运动场材料厂家_中国塑胶跑道十大生产厂家_混合型塑胶跑道_透气型塑胶跑道-广东绿晨体育设施有限公司 | 深圳品牌设计公司-LOGO设计公司-VI设计公司-未壳创意 | 高空重型升降平台_高空液压举升平台_高空作业平台_移动式升降机-河南华鹰机械设备有限公司 | 计算机毕业设计源码网| loft装修,上海嘉定酒店式公寓装修公司—曼城装饰 | 全自动翻转振荡器-浸出式水平振荡器厂家-土壤干燥箱价格-常州普天仪器 | 滁州高低温冲击试验箱厂家_安徽高低温试验箱价格|安徽希尔伯特 | 空气净化器租赁,空气净化器出租,全国直租_奥司汀净化器租赁 | 广西教师资格网-广西教师资格证考试网| 盘煤仪,盘料仪,盘点仪,堆料测量仪,便携式激光盘煤仪-中科航宇(北京)自动化工程技术有限公司 | 拉卡拉POS机官网 - 官方直营POS机办理|在线免费领取 | 上海噪音治理公司-专业隔音降噪公司-中广通环保 | 四川成都干燥设备_回转筒干燥机_脉冲除尘器_输送设备_热风炉_成都川工星科机电设备有限公司 | 河南橡胶接头厂家,河南波纹补偿器厂家,河南可曲挠橡胶软连接,河南套筒补偿器厂家-河南正大阀门 |