Django学习笔记三:QuerySet使用详解
Django的QuerySet是Django ORM中用于表示数据库查询结果集合的对象。它提供了丰富的方法来操作和查询数据库。以下是一些常用的QuerySet方法和操作的详解:
基本查询
filter(*args, **kwargs)
: 返回一个新的QuerySet,包含与给定参数匹配的对象。exclude(*args, **kwargs)
: 返回一个新的QuerySet,包含与给定参数不匹配的对象。annotate(*args, **kwargs)
: 使用提供的查询表达式列表对QuerySet中的每个对象进行注解。
高级查询
order_by(*fields)
: 用于对QuerySet的结果进行排序。reverse()
: 反转QuerySet中的顺序。
聚合查询
aggregate(*args, **kwargs)
: 对QuerySet计算聚合值,如平均值、总和等。
计数和存在性
count()
: 返回QuerySet中的记录数。exists()
: 如果QuerySet包含任何结果,则返回True。
检索特定对象
get(*args, **kwargs)
: 返回与给定查找参数相匹配的唯一对象。如果找不到对象或找到多个对象,将分别抛出DoesNotExist
或MultipleObjectsReturned
异常。first()
: 返回QuerySet中的第一个对象,如果没有对象则返回None。last()
: 返回QuerySet中的最后一个对象,如果没有对象则返回None。
更新和删除
update(**kwargs)
: 对QuerySet中的记录执行SQL更新操作。delete()
: 删除QuerySet中的所有对象。
特殊方法
distinct()
: 返回一个新的QuerySet,在其SQL查询中使用SELECT DISTINCT
,消除查询结果中的重复记录。values(*fields, **expressions)
: 返回一个包含指定字段的字典列表。values_list(*fields, flat=False, named=False)
: 返回一个包含指定字段值的元组列表。
分批处理
iterator(chunk_size=None)
: 用于迭代查询结果,可以指定chunk_size来控制每次从数据库中获取的记录数。
聚合查询
earliest(*fields)
: 返回QuerySet中最早的对象。latest(*fields)
: 返回QuerySet中最新的对象。
示例
from django.db.models import Min, Max, Avg, Count
# 获取所有博客文章
entries = Entry.objects.all()
# 获取标题包含"Django"的博客文章
entries = Entry.objects.filter(title__contains="Django")
# 按发布日期排序
entries = entries.order_by('pub_date')
# 获取最早的和最新的博客文章
earliest_entry = Entry.objects.earliest('pub_date')
latest_entry = Entry.objects.latest('pub_date')
# 聚合查询,计算平均分
average_score = Entry.objects.aggregate(Avg('score'))
# 更新操作
Entry.objects.filter(is_published=False).update(is_published=True)
# 删除操作
Entry.objects.filter(is_published=False).delete()
QuerySet提供了非常灵活的方式来处理数据库操作,使得开发者可以使用Python代码来完成大部分数据库操作,而无需编写复杂的SQL语句。