Django ORM的QuerySet:解锁数据库交互的魔法钥匙

在这里插入图片描述
用到此篇文章知识的几篇文章:

  • Django ORM实战:模型字段与元选项配置,以及链式过滤与QF查询详解
  • Django API开发实战:前后端分离、Restful风格与DRF序列化器详解

文章目录

  • 前言
  • 一、什么是QuerySet?
  • 二、QuerySet 的用途
  • 三、如何使用 QuerySet?
  • 四、QuerySet 的原理


前言

    在Django的广阔世界里,ORM(对象关系映射)是连接数据库与Python代码的桥梁。而在这座桥梁上,QuerySet无疑是最耀眼的明星。它不仅简化了复杂的数据库操作,还提供了丰富的查询和过滤功能,使得开发者能够轻松地在数据库与应用程序之间穿梭。本文将带你领略QuerySet的魅力,解析其概念、用途、原理,并附上实用的使用方法,让你在Django的开发之路上更加游刃有余。


一、什么是QuerySet?

QuerySet 是 Django 提供的一个高级接口,用于对数据库中的数据进行查询和操作。它是一个包含一系列数据库查询指令的集合,而不是实际的数据行。
QuerySet 对象是惰性的(lazy),这意味着它们不会立即执行查询,直到你真正需要结果时才会执行。

二、QuerySet 的用途

  1. 查询数据:可以对数据库中的记录进行筛选、排序、聚合等操作。
  2. 数据聚合:使用 aggregate 方法进行数据的统计和计算。
  3. 数据注释:使用 select_relatedprefetch_related 优化数据库查询,减少查询次数。
  4. 切片和迭代:可以对 QuerySet 进行切片,获取特定范围的结果,也可以迭代 QuerySet 获取所有结果。
  5. 链式调用QuerySet 方法返回 QuerySet 对象,支持链式调用,使得查询构建清晰且易于阅读。

三、如何使用 QuerySet?

1. 基本查询

entries = Entry.objects.all()  # 获取所有记录

2. 筛选

entries = Entry.objects.filter(published_date__lte=timezone.now())

3. 排除

entries = Entry.objects.exclude(is_draft=True)

4. 排序

entries = Entry.objects.order_by('published_date')

5. 聚合

from django.db.models import Count
entries = Entry.objects.values('author').annotate(total=Count('id'))

6. 切片

first_five_entries = Entry.objects.all()[:5]  # 获取前五条记录

7. 迭代

for entry in Entry.objects.all():print(entry.title)

8. 链式调用

entries = Entry.objects.filter(is_published=True).order_by('-date_published')

四、QuerySet 的原理

QuerySet 的工作原理基于生成器模式当你创建一个 QuerySet 时,Django 会构建一个查询,但不会立即执行它只有当你需要 QuerySet 的数据时,Django 才会执行查询。这有几个关键点:

  1. 惰性执行QuerySet 直到真正需要数据时才执行查询,这可以避免不必要的数据库访问。
  2. 查询优化:Django 会在内部优化查询,比如合并多个查询为一个,减少数据库的访问次数。
  3. 数据库抽象QuerySet 允许开发者以一种数据库无关的方式来编写数据库查询,Django 会将这些查询转换成适合底层数据库的 SQL。
  4. 缓存:Django 可以对 QuerySet 结果进行缓存,以提高性能。

QuerySet 是 Django ORM 的强大工具,它使得数据库操作变得简单、直观且高效。通过 QuerySet,开发者可以轻松地构建复杂的数据库查询,同时保持代码的清晰和可维护性。


对QuerySet进行手动处理:

# 序列化
#query_set<[object, obj2]>
book_set = Book.objects.all()books = []
#  遍历 每一个 模型对象
for book in book_set:books.append({'id': book.id,'btitle': book.btitle,'price': book.price,'bread': book.bread,'bcomment': book.bcomment})

反序列化:django将前端传递的json格式的字符串数据接收并转换为模型对象,这个过程称之为反序列化。

对获取的json数据,手动进行反序列化:

#获取前端传递数据
json_dict = request.data
json_dict = {"btitle":"光年""price":18.8,"bread":20,"bcomment":200
}# 模型对象,将获取的json格式数据插入
obj = Book()
obj.btitle = json_dict['btitle']
obj.price = json_dict['price']
obj.bread = json_dict['bread']
obj.bcomment = json_dict['bcomment']
ojb.save()

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/25699.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Dell服务器根据GPU温度调整风扇转速

前言 dell服务器自动风扇是根据CPU温度来调速的&#xff0c;我跑AI的时候cpu温度不高但是GPU温度很高导致显卡卡死PVE虚拟机直接挂起无法运行&#xff0c;我看了下也没有基于显卡温度调速的脚本&#xff0c;于是我就自己写了一个 基于ipmi工具 乌班图等linux先安装ipmi apt …

搭建vauditdemo靶场mysql为NO问题

一、问题 在搭建vauditdemo时&#xff0c;遇到如下显示问题&#xff1a; mysql版本检测为NO 二、解决 查找该方面问题时&#xff0c;并没有找到解决方法 然后换mysql版本换了五六个也没有解决问题 问了AI后给的答复有一条为将mysql改为mysqli 修改保存后解决问题 步骤如…

二分【1】二分查找框架 查找指定元素

目录 二分查找 基本思想 几种情况汇总 一。严格递增序列 1.查找本身 2.查找第一个大于等于自己的 3.查找第一个大于自己的 4.严格递减序列 二。有重复元素 1.取其中第一个出现的 2.取其中最后一个出现的 二分查找 基本思想 几种情况汇总 一。严格递增序列 1.查找本身…

作业-day-240607

思维导图 C编程 要求&#xff1a; 搭建一个货币的场景&#xff0c;创建一个名为 RMB 的类&#xff0c;该类具有整型私有成员变量 yuan&#xff08;元&#xff09;、jiao&#xff08;角&#xff09;和 fen&#xff08;分&#xff09;&#xff0c;并且具有以下功能&#xff1a;…

模板显式、隐式实例化和(偏)特化、具体化的详细分析

最近看了<The C Programing Language>看到了模板的特化&#xff0c;突然想起来<C Primer>上说的显式具体化、隐式具体化、特化、偏特化、具体化等概念弄得头晕脑胀&#xff0c;我在网上了找了好多帖子&#xff0c;才把概念给理清楚。 看着这么多叫法&#xff0c;其…

上位机图像处理和嵌入式模块部署(f407 mcu vs h750)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 在目前工业控制上面&#xff0c;f103和f407是用的最多的两种stm32 mcu。前者频率低一点&#xff0c;功能少一点&#xff0c;一般用在低端的嵌入式设…

C语言详解(文件操作)1

Hi~&#xff01;这里是奋斗的小羊&#xff0c;很荣幸您能阅读我的文章&#xff0c;诚请评论指点&#xff0c;欢迎欢迎 ~~ &#x1f4a5;&#x1f4a5;个人主页&#xff1a;奋斗的小羊 &#x1f4a5;&#x1f4a5;所属专栏&#xff1a;C语言 &#x1f680;本系列文章为个人学习…

通过在idea上搭建虚拟hadoop环境使用MapReduce做词频去重

idea上的MapReduce ​ 一般在开发中&#xff0c;若是等到环境搭配好了再进行测试或者统计数据&#xff0c;数据处理等操作&#xff0c;那会很耽误时间&#xff0c;所以一般都是2头跑&#xff0c;1波人去在客户机上搭建环境&#xff0c;1波人通过在idea上搭建虚拟hadoop环境&am…

Vue3父组件如何访问子组件属性和方法

本篇内容主要是父组件如何访问子组件的属性和方法 文章目录 子组件 //son.vue代码const list (info) >{console.log(info) }const name ref("XXXX")//子组件向父组件暴露了一个方法&#xff0c;然后父组件就可以去使用子组件里面的一些属性和方法了 //子组件向…

奇安信停服,国内还有什么可用的高防么?

这里写自定义目录标题 背景DDOS怎么办&#xff1f;方案推荐总结 背景 继前段时间百度云加速通知免费服务&#xff0c;6月底奇安信也将停止服务&#xff0c;到时候国内将几乎不存在免费好用的高防CDN了&#xff1b;类似的事情还有阿里云和腾讯云的一年期免费SSl证书也都停止供应…

C++:SLT容器-->deque

C:SLT容器-->deque 1. 构造函数2. deque 赋值操作3. deque 大小操作4. deque 插入和删除5. deque 容器数据存取6. deque 排序操作 双端数组&#xff0c;可以对头部和尾部进行插入删除操作 需要导入头文件#include <deque> 1. 构造函数 deque deqT; // 默认构造函数 de…

vue-2 组件传值

组件关系分类 父子关系非父子关系 父子通信流程 父组件通过props将数据传递给子组件 给子组件以添加属性的方式传值子组件内部通过 props 接收模板中直接使用 props 接收的值 父组件 Parent.vue <template><div class"parent" style"border: 3px s…

CST Studio Suite 2020 软件安装教程、安装包下载

CST Studio Suite 2020 安装教程 安装包下载 复制链接在浏览器打开 https://www.qqres.com/3150.html CST Studio Suite 是由Dassault Systmes公司开发的一套电磁场仿真软件。它应用于电子、通信、天线设计、射频与微波、电磁兼容性 (EMC)、电磁干扰 (EMI) 等领域。 CST St…

Unity协程学习心得

前言 个人总结的一些Unity协程学习心得&#xff0c;如有不对请在评论区指出一起学习&#xff01;感谢。 在Unity编程中谈到异步逻辑&#xff0c;可以考虑使用协程来实现。协程&#xff08;Coroutine&#xff09;在Unity中的主要作用就是把一个任务暂停&#xff08;挂起&#…

智慧园区建设方案(Word)

1. 楼栋管理 2. 物业管理 3. 安防管理 4. 门禁管理 5. 停车管理 6. 能源管理 7. 环保管理 8. 园区生活服务 9. 招商管理 10. 收费中心 11. 园区地图 12. 门户网站 软件整套原件获取&#xff1a;本文末个人名片。

使用DPO微调大模型Qwen2详解

简介 基于人类反馈的强化学习 (Reinforcement Learning from Human Feedback&#xff0c;RLHF) 事实上已成为 GPT-4 或 Claude 等 LLM 训练的最后一步&#xff0c;它可以确保语言模型的输出符合人类在闲聊或安全性等方面的期望。但传统的RLHF比较复杂&#xff0c;且还需要奖励…

BabylonJS 6.0文档 Deep Dive 动画(四):通过动画排序制作卡通片

一种最为直接的方法是为每个动画剪辑&#xff08;Animatin Clip&#xff09;指定开始时间&#xff0c;最终形成一个卡通动画&#xff08;Cartoon&#xff09;。 1. 设计 1.1 概述 动画的脚本如下&#xff1a; 摄像机显示了一栋带门的建筑物。摄像机靠近门并停止。门打开&am…

掌控数据流:深入解析 Java Stream 编程

Java 8 引入了一种新的抽象称为流&#xff08;Stream&#xff09;&#xff0c;它可以让你以一种声明的方式处理数据。Java 8 Stream API 可以极大提高 Java 程序员的生产力&#xff0c;使代码更简洁&#xff0c;更易读&#xff0c;并利用多核架构进行外部迭代。这里将详细介绍 …

【NoSQL数据库】Redis简介

Redis Redis简介 Redis关系型数据库和非关系型数据库Redis 简介redis速度快的原因 Redis 配置Linux 源码安装redis命令工具 关系型数据库和非关系型数据库 关系型数据库&#xff08;Relational Database&#xff09;和非关系型数据库&#xff08;Non-Relational Database&…

重学Spring总结

1、Spring框架的诞生 文章目录 1、Spring框架的诞生1、BeanFactory 快速入门1.1、BeanFactory完成了loC思想的实现&#xff1a;1)导入Spring相关的依赖&#xff1a;2)定义Uservice接口及其UserviceImpl实现类&#xff1b;3)创建Bean的配置资源文件&#xff0c;文件名最好为&…