Django之ORM操作(聚合 分组、F Q)
Django之ORM操作(聚合 分组、F Q)
聚合
aggregate()是QuerySet的一个终止子句,也就是说,他返回一个包含一些键值对的字典,在它的后面不可以再进行点(.)操作.
键的名称是聚合值的标识符,只是计算出来的聚合值.键的名称是按照字段和聚合函数的名称自动生成出来的.
聚合函数的导入
from django.db.models import Max, Min, Sum, Avg, Count
简单使用示例:
查询所有书的平均价格.
from django.db.models import Avg, Sum, Max, Min, Count ret = models.Book.objects.all().aggregate(Avg("price")) >>> {'price__avg': 13.233333} # price__avg 是自动成出来的,前边是聚合的字段,后边是聚合函数的名称.
当需要为聚合值指定一个名称,可以向聚合子句提供它.
from django.db.models import Avg, Sum, Max, Min, Count models.Book.objects.aggregate(average_price=Avg('price')) # average_price 为自己指定的名称.
>>> {'average_price': 13.233333}
当需要生成不止一个聚合时,可以向aggregate()子句中添加另一个参数.
查询所有图书价格的平均值 最大值 最小值.
from django.db.models import Avg, Sum, Max, Min, Count models.Book.objects.all().aggregate(Avg("price"), Max("price"), Min("price")) # >>> {'price__avg': 13.233333, 'price__max': Decimal('19.90'), 'price__min': Decimal('9.90')}
查询所有图书中最高的价格和平均价格
from django.db.models import Max, Avg ret = models.Book.objects.aggregate(Max('price'), avg=Avg('price')) #
分组
现有员工表如下:
需求:
按照部门分组求平均工资
ORM操作如下:
from django.db.models import Avg models.Employee.objects.values("dept").annotate(avg=Avg("salary").values("dept", "avg") #
按照哪个字段分组,就将哪个字段写在objects后面的values中.
注意:
分组使用的是annotate(),他不是一个终止子句,他的后边可以跟其他操作.
连表查询:
表格如下:
按照部门分组求平均工资:
from django.db.models import Avg models.Dept.objects.annotate(avg=Avg("employee__salary")).values("name", "avg") #
按照部门分组,就从部门表上开始查,聚合函数Avg()中写需要差的字段,按照双下划线的方法找到字段.
其他示例:
统计每一本书的作者的数量
from app01 import models
from django.db.models import Count ret = models.Book.objects.annotate(Count('author')).values() #
查询每个出版社出版的图书中价格最低的
方式一:
from app01 import models
from django.db.models import Min ret = models.Publisher.objects.annotate(Min('book__price')).values() #
从出版社表查,聚合函数Min()中写需要查询的字段,使用双下滑线(__)的方法查询到需要的字段.
方式二:
from app01 import models
from django.db.models import Min ret = models.Book.objects.values('publisher__name').annotate(min=Min('price')) #
从书表中查,objects后面的values()中写分组依据的字段名.然后跟annotate()中写聚合函数,聚合函数中写查询的字段.
查询作者大于1的图书
from app01 import models
from django.db.models import Count ret = models.Book.objects.annotate(count=Count('author')).filter(count__gt=1).values() #
从书表中查询,先统计每一本书的作者的数量,然后使用filter()过滤出符合条件的对象.
查询每位作者所出书的总价格
from app01 import models
from django.db.models import Sum ret = models.Author.objects.annotate(Sum('books__price')).values() #
从作者表查询,聚合函数Sum()中填写查询的字段
F
在此之前我们构造的过滤器都只是将字段与某个常量作比较,如果将两个字段做比较时,可以使用F().F()的实例可以再查询中引用字段,来比较同一个model实例(对象)中的两个不同字段的值.
简单点说就是可以用来动态数据对比查询.
F的导入
from django.db.models import F
查询销量大于库存的图书
from django.db.models import F ret = models.Book.objects.filter(sale__gt=F('kucun')).values() #
F的用法是F('字段名'),F()是用来取值的.
将所有书的销量更新为原来的2倍.
from app01 import models
from django.db.models import F ret = models.Book.objects.all().update(sale=F('sale') * 2) #
可以进行翻倍操作.
PS:
知识补充 ---> .update() 更新
仅对选中的QuerySet对象进行更新,速度快.
from app01 import models ret = models.Book.objects.filter(id=2).update(sale=100) #
将id为2的书的销量设置为100.
将所有书的销量更新为原来的2倍.
1 from app01 import models
2 from django.db.models import F
3
4 ret = models.Book.objects.all().update(sale=F('sale') * 2) #
可以进行翻倍操作.
知识补充 ---> .save() 修改后进行保存.
对所有对象都进行保存,操作数据量大,速度慢.
from app01 import models obj = models.Book.objects.get(id=2)
obj.sale=''
obj.save()
将id为2的书的销量设置为1000.
Q
filter()等方法中的关键字参数查询都是一起进行'and'的,如果需要进行更加复杂的查询,可以使用Q对象.
示例:
查询id小于等于3或者id大于等于6的书
from app01 import models
from django.db.models import Q ret = models.Book.objects.filter(Q(id__lte=3) | Q(id__gte=6)) #
Q()写在filter()中,使用或(or)查询是每个Q()使用管道符(|)连接,管道符表示或(or)的关系.
查询id大于等于10并且销量大于等于3000的书.
from app01 import models
from django.db.models import Q ret = models.Book.objects.filter(~Q(price__gte=10) & Q(sale__gte=3000)).values() #
使用&连接时表示and.
Django之ORM操作(聚合 分组、F Q)的更多相关文章
- Django之ORM操作
Django之ORM操作 前言 Django框架功能齐全自带数据库操作功能,本文主要介绍Django的ORM框架 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计 ...
- 【Django】ORM操作#2
目录 必知必会的13条查询方法 单表查询之神奇的双下划线 一对多 ForeignKey 多对多 ManyToManyField 在Python脚本中调用Django环境 Django终端打印SQL语句 ...
- Django之ORM操作(***)
Django之ORM操作(***) http请求的流程: url--> 视图view(模板+数据库) --> ORM的功能: 可以转换SQL语句,并做操作. ORM操作数据表: -创建表: ...
- 【Django】ORM操作#1
目录 一.介绍 概念 由来 优势 劣势 总结 二.Django中的ORM Django项目使用MySQL Model 快速入门 1. AutoField 2. IntegerField 3. Char ...
- Django中ORM的聚合索引
Django中ORM的聚合索引 在Django中,聚合函数是通过aggregate方法实现的,aggregate方法返回的结果是一个字典 在使用时需要先导入模块from django.db.mod ...
- django的orm操作优化
django的orm操作优化 models.py from django.db import models class Author(models.Model): name = models.Char ...
- ORM( ORM查询13种方法3. 单表的双下划线的使用 4. 外键的方法 5. 多对多的方法 ,聚合,分组,F查询,Q查询,事务 )
必知必会13条 <1> all(): 查询所有结果 <2> get(**kwargs): 返回与所给筛选条件相匹配的对象,返回结果有且只有一个,如果符合筛选条件的对象超过一个或 ...
- python-day71--django多表双下划线查询及分组聚合及F/Q查询
#====================================双下划线的跨表查询===============# 前提 此时 related_name=bookList 属性查询: # 查 ...
- Django之ORM操作(重要)
Django ORM操作 一般操作 看专业的官网文档,做专业的程序员! 必知必会13条 <1> all(): 查询所有结果 <2> get(**kwargs): 返回与所给 ...
随机推荐
- [Hive_add_1] Hive 与 MR 的对应关系
- 注入攻击(SQL注入防御)
正确的防御SQL注入 sql注入的防御不是简单只做一些用户输入的escape处理,这样是不够的,只是提高了攻击者的门槛而已,还是不够安全. 例如 mysql_real_escape_string()函 ...
- JavaScript原型链和继承
1.概念 JavaScript并不提供一个class的实现,在ES6中提供class关键字,但是这个只是一个语法糖,JavaScript仍然是基于原型的.JavaScript只有一种结构:对象.每个对 ...
- fg和bg前后台调度命令
Linux下的fg和bg命令是进程的前后台调度命令,即将指定号码(非进程号)的命令进程放到前台或后台运行.比如一个需要长时间运行的命令,我们就希望把它放入后台,这样就不会阻塞当前的操作:而一些服务型的 ...
- eclipse使用CXF3.1.*创建webservice服务端客户端以及客户端手机APP(一)
eclipse使用CXF3.1.*创建webservice服务端客户端以及客户端手机APP(一) 本篇博客主要包含五个内容: 1.CXF换将搭建以及eclipse配置CXF. 2.eclipse创建w ...
- 用惯图形界面的SVNer,如何突破Git----简单教程
1.使用Git,首先安装好Git,它会赠送一个Git Bash给你 2.接下来,踩第一个坑----SSH连接,我们知道用Git关联本地仓库可以用SSH和HTTP两种方式,为什么不用HTTP,因为 不! ...
- B树索引分裂
一.索引分裂 1. 什么是分裂 在开始介绍之前,我们先来搞清楚什么是索引分裂吧.“索引分裂”就是索引块的分裂,当一次DML事务操作修改了索引块上的数据,但是旧有的索引块没有足够的空间来容纳新修改的数 ...
- Oracle调整顾问(SQL Tuning Advisor 与 SQL Access Advisor
在Oracle数据库出现性能问题时,使用Oracle本身的工具包,给出合理的调优建议是比较省力的做法. tuning advisor 是对输入的sql set的执行计划进行优化accsee advis ...
- Quartz Cron表达式详解
转:https://www.jianshu.com/p/f03b1497122a 本文包含如下内容 CronTrigger简介 Cron 表达式 Cron表达式可选的值 Cron表达式的配置规则 Cr ...
- L2-010 排座位 (并查集)
这里唯一需要注意的是,各个输出的条件在题目中有点描述模糊. 是朋友关系,(不管是不是间接朋友关系) 既不是朋友也不是敌人(这里不用管是不是间接朋友) 是敌人关系,同时是间接朋友关系 是单纯的敌人关系, ...