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): 返回与给定查找参数相匹配的唯一对象。如果找不到对象或找到多个对象,将分别抛出DoesNotExistMultipleObjectsReturned异常。
  • 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中最新的对象。

示例

python 复制代码
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语句。

相关推荐
biter008833 分钟前
opencv(15) OpenCV背景减除器(Background Subtractors)学习
人工智能·opencv·学习
车轮滚滚__43 分钟前
uniapp对接unipush 1.0 ios/android
笔记
Code哈哈笑2 小时前
【Java 学习】深度剖析Java多态:从向上转型到向下转型,解锁动态绑定的奥秘,让代码更优雅灵活
java·开发语言·学习
QQ同步助手2 小时前
如何正确使用人工智能:开启智慧学习与创新之旅
人工智能·学习·百度
流浪的小新3 小时前
【AI】人工智能、LLM学习资源汇总
人工智能·学习
A懿轩A3 小时前
C/C++ 数据结构与算法【数组】 数组详细解析【日常学习,考研必备】带图+详细代码
c语言·数据结构·c++·学习·考研·算法·数组
云边有个稻草人3 小时前
【优选算法】—复写零(双指针算法)
笔记·算法·双指针算法
云和数据.ChenGuang8 小时前
Django 应用安装脚本 – 如何将应用添加到 INSTALLED_APPS 设置中 原创
数据库·django·sqlite
南宫生11 小时前
力扣-图论-17【算法学习day.67】
java·学习·算法·leetcode·图论
sanguine__11 小时前
Web APIs学习 (操作DOM BOM)
学习