Django之ORM对象方法,聚合、分组、F、Q查询

    xiaoxiao2022-06-26  179

    对象的方法

    <1> all(): 查询所有结果 <2> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象,不存在返回一个空的QuerySet <3> get(**kwargs): 返回与所给筛选条件相匹配的对象,返回结果有且只有一个,如果符合筛选条件的对象超过一个或者没有都会抛出错误。 <4> exclude(**kwargs): 它返回不符合筛选条件的对象 <5> values(*field): 返回一个ValueQuerySet——一个特殊的QuerySet,运行后得到的并不是一系列model的实例化对象,而是一个可迭代的字典序列 <6> values_list(*field): 它与values()非常相似,它返回的是一个元组序列,values返回的是一个字典序列 <7> order_by(*field): 对查询结果排序 <8> reverse(): 对查询结果反向排序,请注意reverse()通常只能在具有已定义顺序的QuerySet上调用(在model类的Meta中指定ordering或调用order_by()方法)。 <9> distinct(): 从返回结果中剔除重复纪录(如果你查询跨越多个表,可能在计算QuerySet时得到重复的结果。此时可以使用distinct(),注意只有在PostgreSQL中支持按字段去重。) <10> count(): 返回数据库中匹配查询(QuerySet)的对象数量。 <11> first(): 返回第一条记录 <12> last(): 返回最后一条记录 <13> exists(): 如果QuerySet包含数据,就返回True,否则返回False

    单表查询双下划綫

    models.Tb1.objects.filter(id__lt=10, id__gt=1) # 获取id大于1 且 小于10的值 models.Tb1.objects.filter(id__in=[11, 22, 33]) # 获取id等于11、22、33的数据 models.Tb1.objects.exclude(id__in=[11, 22, 33]) # not in models.Tb1.objects.filter(name__contains="ven") # 获取name字段包含"ven"的 models.Tb1.objects.filter(name__icontains="ven") # icontains大小写不敏感 models.Tb1.objects.filter(id__range=[1, 3]) # id范围是1到3的,等价于SQL的bettwen and

    ForeignKey操作

    class Publisher(models.Model): id = models.AutoField(primary_key=True) name = models.CharField(max_length=32, unique=True) def __str__(self): return "我是一个出版社对象:{}".format(self.name) class Book(models.Model): id = models.AutoField(primary_key=True) price = models.DecimalField(max_digits=5, decimal_places=2, default=99.99) # 库存数 kucun = models.IntegerField(default=1000) # 卖出数 maichu = models.IntegerField(default=0) title = models.CharField(max_length=32) # 外键 # related_name="books" 反向查询是用来代替 book_set的 publisher = models.ForeignKey( to="Publisher", on_delete=models.CASCADE, related_name="books", related_query_name="xxoo", null=True ) def __str__(self): return self.title class Author(models.Model): id = models.AutoField(primary_key=True) name = models.CharField(max_length=32) books = models.ManyToManyField(to="Book") def __str__(self): return self.name 正向查找 对象查找 对象.关联字段.字段 book_obj = models.Book.objects.first() # 第一本书对象 print(book_obj.publisher) # 得到这本书关联的出版社对象 print(book_obj.publisher.name) # 得到出版社对象的名称 修改 book_obj = models.Book.objects.get(id=9) book_obj.title=request.POST.get("title") book_obj.publisher_id=9 book_obj.save() 字段查找 关联字段__字段 书里面的publisher字段 print(models.Book.objects.values_list("publisher__name")) 反向查找 对象查找 obj.表名_set # related_name="books" 反向查询是用来代替 book_set的 publisher = models.ForeignKey( to="Publisher", on_delete=models.CASCADE, related_name="books", related_query_name="xxoo", null=True ) 1. 基于对象查询 publisher_obj = models.Publisher.objects.first() # 找到第一个出版社对象 books = publisher_obj.book_set.all() # 找到第一个出版社出版的所有书 books = publisher_obj.books.all() # 找到第一个出版社出版的所有书 2. 基于双下划线 titles = models.Publisher.objects.values_list("book__title") titles = models.Publisher.objects.filter(id=1).values_list("xxoo__title") print(ret)

    ManyToManyField方法

    create() 创建一个新的对象,保存对象,并将它添加到关联对象集之中,返回新创建的对象。 models.Author.objects.first().book_set.create(title="番茄物语") add() 把指定的model对象添加到关联对象集中。 book_obj = model.Book.objects.get(id=1) models.Author.objects.first().add(book_obj) models.Author.objects.first().add(1) author_objs = models.Author.objects.filter(id__lt=3) models.Book.objects.first().authors.add(*author_objs) set()更新model对象的关联对象。 book_obj = models.Book.objects.first() book_obj.authors.set([2, 3]) remove() 从关联对象集中移除执行的model对象 book_obj = models.Book.objects.first() author_obj.remove(book_obj) author_obj.remove(1) clear()从关联对象集中移除一切对象。 book_obj = models.Book.objects.first() book_obj.authors.clear() 注意:对于ForeignKey对象,clear()和remove()方法仅在null=True时存在。

    聚合查询和分组

    聚合 aggregate()是QuerySet 的一个终止子句,意思是说,它返回一个包含一些键值对的字典。 键的名称是聚合值的标识符,值是计算出来的聚合值。键的名称是按照字段和聚合函数的名称自动生成出来的。 用到的内置函数: from django.db.models import Avg, Sum, Max, Min, Count models.Book.objects.all().aggregate(Avg("price")) 如果你想要为聚合值指定一个名称,可以向聚合子句提供它。 models.Book.objects.all().aggregate(average_price=Avg('price')) 分组 单独表的分组查询 from django.db.models import Avg models.Employee.objects.all().values("dept").annotate(avg=Avg("salary")).values("dept","avg") 连表分组的查询 from django.db.models import Avg models.Dept.objects.annotate(avg=Avg("employee__salary")).values("name","avg")

    F查询和Q查询

    from django.db.models import F F可以取到字段keep_num的值,和commnet_num比较 models.Book.objects.filter(commnet_num__gt=F('keep_num')) 查询作者名是小仙女或小魔女的 models.Book.objects.filter(Q(authors__name="小仙女")|Q(authors__name="小魔女")) 查询函数可以混合使用Q对象和关键字参数。所有提供给查询函数的参数(关键字参数或Q 对象)都将"AND”在一起。但是,如果出现Q对象,它必须位于所有关键字参数的前面。 models.Book.objects.filter(Q(publish_date__year=2018) | Q(publish_date__year=2017), title__icontains="物语")

    最新回复(0)