先补充两个知识点: 1.group by 大前提:可以按照任意字段分组,但是最好是按照分辨度比较低的来分组(重复比较多的分辨度比较低). group by分组可以单独使用,不搭配其他条件. 分组的字段重复的会被隐去,如果想查看可以用固定的函数去查看. 分组主要是为了查看分组后该字段每个组的个数 select post,count(*) from emp where id>3 group by post having count(id) >5 2.having having是将通过where查询…
一.多表的创建 from django.db import models # Create your models here. class Author(models.Model): id = models.AutoField(primary_key=True) name = models.CharField(max_length=32) age = models.IntegerField() au = models.OneToOneField(to='AuthorDetail',to_fiel…
ret=Emp.objects.values('dep').annotate(avg_salary=Avg('salary')) print(ret) # ---*******单表分组查询ORM总结:表名.objects.values('group by 的字段').annotate(聚合函数('统计的字段') from django.db.models import Avg,Count,Min,Max ret = models.Publish.objects.values('nid').ann…
1.聚合查询 # 聚合函数aggregate,求指定字段的最大值,最小值,平均值,和的值,方法如下 from django.db.models import Avg from django.db.models import Sum from django.db.models import Max from django.db.models import Min obj = models.book.objects.all().aggregate(Avg("Book_price")) pr…