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语句。

相关推荐
red_redemption1 小时前
自由学习记录(175)
学习
ZhiqianXia2 小时前
《The Design of Design》阅读笔记
前端·笔记·microsoft
nashane2 小时前
HarmonyOS 6学习:画中画(PiP)状态同步与场景化实战指南
学习·pip·harmonyos·harmonyos 5
祁白_2 小时前
nmap工具笔记整理
笔记·web安全·测试
_李小白2 小时前
【android opencv学习笔记】Day 8: remap(像素位置重映射)
android·opencv·学习
勤劳的进取家2 小时前
数据链路层基础
网络·学习·算法
南境十里·墨染春水2 小时前
C++笔记 STL——set
开发语言·c++·笔记
d111111111d2 小时前
直流电机位置式 PID 控制 和 舵机的区别
笔记·stm32·单片机·嵌入式硬件·学习
LZYmarks3 小时前
小白买车笔记
笔记
码途漫谈3 小时前
Easy-Vibe开发篇阅读笔记(二)——前端开发之Figma与MasterGo入门
人工智能·笔记·ai·开源·ai编程·figma