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

相关推荐
吃杠碰小鸡18 分钟前
前端 IndexedDB 完全指南
学习
宵时待雨26 分钟前
C++笔记归纳14:AVL树
开发语言·数据结构·c++·笔记·算法
问道飞鱼1 小时前
【大模型学习】LangGraph 深度解析:定义、功能、原理与实践
数据库·学习·大模型·工作流
左左右右左右摇晃1 小时前
JDK 1.7 ConcurrentHashMap——分段锁
java·开发语言·笔记
烤麻辣烫1 小时前
I/O流 基础流
java·开发语言·学习·intellij-idea
云边散步2 小时前
godot2D游戏教程系列二(22)
笔记·学习·游戏
jincheng_2 小时前
软件设计师上午题|9模块极速背诵版
学习
Schengshuo2 小时前
Spring学习——新建module模块
java·学习·spring
chushiyunen2 小时前
langchain实现agent智能体笔记
笔记·langchain
jyan_敬言2 小时前
【算法】高精度算法(加减乘除)
c语言·开发语言·c++·笔记·算法