聚合函数 取名: field + __ + 聚合函数名字 ,如:price__avg;可传关键字参数修改名字:avg=Avg("price");

aggregate:不会返回一个 QuerySet 对象,而是返回一个字典,key为聚合函数的名字,value为聚合函数执行结果;

annotate:返回一个 QuerySet 对象;

相同点:

  1. 都可执行聚合函数;可在任何的‘QuerySet’对象上调用,因此只要返回了‘QuerySet’对象,即可进行链式调用,如 index5 中获取年度销售总额,可先过滤年份再求聚合函数;

不同点:

  1. aggregate 返回一个字典,字典中存储聚合函数执行的结果;而 annotate 返回一个 QuerySet对象 ,并在查找的模型上添加一个聚合函数的属性;
  2. aggregate 不会做分组,而 annotate 会使用 Group by 字句进行分组,只有调用该字句才能对每一条数据求聚合函数的值;
  • 数据库中的内容

  • models.py文件:

     from django.db import models
    
     class Author(models.Model):
    '''作者模型'''
    name = models.CharField(max_length=100)
    age = models.IntegerField()
    email = models.EmailField() class Meta:
    db_table = 'author' class Publisher(models.Model):
    '''出版社模型'''
    name = models.CharField(max_length=300) class Meta:
    db_table = 'publisher' class Book(models.Model):
    '''图书模型'''
    name = models.CharField(max_length=300)
    pages = models.IntegerField()
    price = models.FloatField()
    rating = models.FloatField()
    author = models.ForeignKey(Author,on_delete=models.CASCADE)
    publisher = models.ForeignKey(Publisher,on_delete=models.CASCADE) class Meta:
    db_table = 'book' class Bookorder(models.Model):
    '''图示订单模型'''
    book = models.ForeignKey('Book',on_delete=models.CASCADE)
    price = models.FloatField()
    create_time = models.DateTimeField(auto_now_add=True,null=True) class Meta:
    db_table = 'book_order'
  • views.py文件:

     from django.shortcuts import render
    from django.http import HttpResponse
    from .models import Author,Publisher,Book,Bookorder
    from django.db.models import Avg,Count,Max,Min,Sum
    from django.db import connection def index(request):
    # 获取所有图书定价的平均价(使用aggregate);Avg:平均值;
    result = Book.objects.aggregate(Avg('price'))
    print(result)
    print(connection.queries)
    return HttpResponse('index')
    # >>>{'price__avg': 97.25}
    # >>>{'price__avg': 97.25}
    # {'sql': 'SELECT AVG(`book`.`price`) AS `price__avg` FROM `book`'; def index2(requset):
    # 获取每一本销售的平均价格(使用annotate);
    books = Book.objects.annotate(avg=Avg('bookorder__price'))
    for book in books:
    print("%s:%s" % (book.name,book.avg))
    print(connection.queries)
    return HttpResponse('index2')
    #三国演义:89.33333333333333
    # 水浒传:93.5
    # 西游记:None
    # 红楼梦:None
    # `book_order` ON (`book`.`id` = `book_order`.`book_id`) GROUP BY `book`.`id` ORDER BY NULL'; def index3(request):
    # book 表中总共有多少本书;
    # Count:求某个数据的的个数;
    result = Book.objects.aggregate(nums=Count('id'))
    # author 表中总共有多少个不同的邮箱;
    # 使用‘distinct=True’剔除重复的值;
    results = Author.objects.aggregate(book_num=Count('email',distinct=True)) # 统计每本书的销量
    books = Book.objects.annotate(book_nums=Count('bookorder'))
    for book in books:
    print("%s:%s" % (book.name,book.book_nums))
    print(books)
    print(connection.queries)
    return HttpResponse("index3")
    # 三国演义:3
    # 水浒传:2
    # 西游记:0
    # 红楼梦:0 def index4(request):
    result = Author.objects.aggregate(max=Max('age'),min=Min('age'))
    # 每本图书售卖前的最大及最小价格;
    books = Book.objects.annotate(max=Max("bookorder__price"),min=Min("bookorder__price"))
    for book in books:
    print("%s:%s:%s" % (book.name,book.max,book.min))
    print(connection.queries)
    return HttpResponse("index4") # 三国演义:95.0:85.0
    # 水浒传:94.0:93.0
    # 西游记:None:None
    # 红楼梦:None:None def index5(request):
    # 求所有图书的销售总额;
    result = Book.objects.aggregate(total=Sum("price"))
    print(result)
    print(connection.queries)
    # {'total': 389.0}
    # {'sql': 'SELECT SUM(`book`.`price`) AS `total` FROM `book`', 'time': '0.001'}; # 求每一本图书的销售总额;
    books = Book.objects.annotate(total=Sum('bookorder__price'))
    for book in books:
    print("%s:%s" % (book.name,book.total))
    print(connection.queries)
    # 三国演义: 268.0
    # 水浒传: 187.0
    # 西游记: None
    # 红楼梦: None # 求2018年度的销售总额;
    result = Bookorder.objects.filter(create_time__year=2019).aggregate(total=Sum("price"))
    # 求2018年度每一本图书的销售总额;
    books = Book.objects.filter(bookorder__create_time__year=2019).annotate(total=Sum("bookorder__price"))
    for book in books:
    print("%s:%s" % (book.name,book.total) )
    print(connection.queries)
    # 三国演义: 268.0
    # 水浒传: 187.0
    # `book_order`.`create_time` BETWEEN '2019-01-01 00:00:00' AND '2019-12-31 23:59:59.999999' GROUP BY `book`.`id`
  • F表达式:动态获取某个字段上的值,不会真正到数据库中查询数据,只起一个标识的作用;

     def index6(requset):
    # 给每本书售价增加10元;update;
    Book.objects.update(price=F('price')+10)
    print(connection.queries[-1])
    # 'UPDATE `book` SET `price` = (`book`.`price` + 10)'; # Author中name与email相同的内容;
    authors = Author.objects.filter(name=F('emile'))
    for author in authors:
    print("%s:%s" % (author.name,author.email))
    return HttpResponse('index6')
  • Q表达式:包裹查询条件,可在条件间进行多种操作:与 & 、或 | 、非 ~  等查询操作;
     def index7(requset):
    # 1、获取价格大于100,评分大于4.5的图书;
    # books = Book.objects.filter(price__gte=100,rating=4.5)
    books = Book.objects.filter(Q(price__gte=100)&Q(rating__gte=4.5))
    for book in books:
    print("%s:%s:%s" % (book.name,book.price,book.rating)) --- # 2、获取价格低于100,或者评分低于4.5分的图书;
    books = Book.objects.filter(Q(price__lt=100)|Q(rating__lt=4.5))
    for book in books:
    print("%s:%s:%s" % (book.name,book.price,book.rating)) --- # 3、获取价格大于100,并且图书名字不包含“传”字的图书;
    books = Book.objects.filter(Q(price__gte=100)&~Q(name__icontains='传'))
    for book in books:
    print("%s:%s:%s" % (book.name,book.price,book.rating))
    return HttpResponse('index7')

聚合函数与F/Q表达式的更多相关文章

  1. Django之ORM操作(聚合 分组、F Q)

    Django之ORM操作(聚合 分组.F Q) 聚合 aggregate()是QuerySet的一个终止子句,也就是说,他返回一个包含一些键值对的字典,在它的后面不可以再进行点(.)操作.   键的名 ...

  2. ORM之自关联、add、set方法、聚合函数、F、Q查询和事务

    一.外键自关联(一对多) 1.建表 # 评论表 class Comment(models.Model): id = models.AutoField(primary_key=True) content ...

  3. 聚合和分组F,Q和事物,cookie,session

    聚合 aggregate()是QuerySet 的一个终止子句,意思是说,它返回一个包含一些键值对的字典. 键的名称是聚合值的标识符,值是计算出来的聚合值.键的名称是按照字段和聚合函数的名称自动生成出 ...

  4. sql语句 之聚合函数

      聚合分析 在访问数据库时,经常需要对表中的某列数据进行统计分析,如求其最大值.最小值.平均值等.所有这些针对表中一列或者多列数据的分析就称为聚合分析. 在SQL中,可以使用聚合函数快速实现数据的聚 ...

  5. Sql Server的艺术(三) SQL聚合函数的应用

    SQL提供的聚合函数有求和,最大值,最小值,平均值,计数函数等. 聚合函数及其功能: 函数名称 函数功能 SUM() 返回选取结果集中所有值的总和 MAX() 返回选取结果集中所有值的最大值 MIN( ...

  6. orm中的聚合函数,分组,F/Q查询,字段类,事务

    目录 一.聚合函数 1. 基础语法 2. Max Min Sum Avg Count用法 (1) Max()/Min() (2)Avg() (3)Count() (4)聚合函数联用 二.分组查询 1. ...

  7. $Django 聚合函数、分组查询、F,Q查询、orm字段以及参数

        一.聚合函数    from django.db.models import Avg,Sum,Max,Min,Count,F,Q   #导入    # .查询图书的总价,平均价,最大价,最小价 ...

  8. Django查找数据库objects.filter() 排序order_by Q()与或非 F()属性之间比较 聚合函数的用法

    条件选取QuerySet的时候,filter表示=参数可以写查询条件,exclude表示!=,querySet.distinct() 去重复(除了get返回值都是QuerySet,可以继续调用所有函数 ...

  9. Django ORM 多对多操作 使用聚合函数和分组 F查询与Q查询

    创建表 # models.py form django.db import models class Book(models.Model): # 表名book,django会自动使用项目名+我们定义的 ...

随机推荐

  1. Linux上配置http上网代理

    有些局域网环境上网需要使用代理上网,图形界面的很好解决就设置一下浏览器的代理就好了,但是Linux纯命令行的界面就需要手动配置了. 如果要全局用户使用应用于所有的Shell,就需要修改 /etc/pr ...

  2. 根据Excel模板,填写报表,并下载到web浏览器端

    package com.neusoft.nda.basic.recordmanager.viewelec.servlet; import java.io.File; import java.io.Fi ...

  3. HTML、CSS知识点,面试开发都会需要--No.5 文章段落

    No.5 文章段落 1.文字属性 文字属性包含font-*和text-*两类. 2.基于font的属性 (1)font-family:字体属性,多个字体之前用逗号隔开.如果第一个字体没找到,则依次找后 ...

  4. try 和 catch 和 finally

    try块中出现异常走进catch,异常后面的代码不会再被执行:finally块里try和catch执行完后要执行的代码,且一定会执行. 在释放资源的时候,不要多个放在一个try块里面. 流的关闭顺序: ...

  5. mysql使用存储过程和event定期删除

    -- 创建存储过程DELIMITER //CREATE PROCEDURE del_data()BEGIN DELETE FROM t_route_status WHERE route_date &l ...

  6. mybatis入门--配置

    1.导入jar包 mybatis-x.x.x.jar 导入到lib目录下, 如果使用 Maven 来构建项目,则需将下面的 dependency 代码置于 pom.xml 文件中: <depen ...

  7. 斑马打印机ZT410中文打印

    ^XA ^CW1, E:SIMSUN.TTF^CI28^FO50,50^A1N,50,50^FD汉字^FS^XZ ******************************************* ...

  8. jsr-303 参数校验—自定义校验注解

    1.为什么要自定义? 通过上篇学习,了解到很多常用注解了,但是呢,总是有那么些需求....   2.案例分析(手机号格式) 2.1.需要验证的实体 Bean public class LoginVo ...

  9. DNSmasq介绍

    DNSmasq介绍 转载自:http://www.cnblogs.com/demonxian3/p/7472300.html#top 云主机的mac地址由物理机的dnsmasq随机分配,如果要修改ma ...

  10. vue router相关用法

    router.push(location) 想要导航到不同的 URL,则使用 router.push 方法.这个方法会向 history 栈添加一个新的记录,所以,当用户点击浏览器后退按钮时,则回到之 ...