【速存】深入理解Django ORM:编写高效的数据库查询

Django作为一个高级Python Web框架,其自带的对象关系映射(ORM)是其最强大的特性之一。ORM允许开发者以编程语言原生的方式操作数据库,而无需编写原始的SQL查询。本文展示如何在Django项目中利用ORM执行各种数据库查询,并提供详细的代码示例及其解释。

基础查询操作

查询所有对象
from myapp.models import MyModel# 获取MyModel表中的所有对象
all_entries = MyModel.objects.all()for entry in all_entries:print(entry)
  • from myapp.models import MyModel: 导入应用中定义的模型。
  • MyModel.objects.all(): 获取MyModel表中的所有对象。
  • for entry in all_entries: 遍历查询到的所有对象,并打印。
过滤查询
# 获取所有is_active为True的对象
active_entries = MyModel.objects.filter(is_active=True)for entry in active_entries:print(entry)
  • MyModel.objects.filter(is_active=True): 使用filter方法筛选出字段is_active值为True的对象。
排除查询
# 获取除了is_active为True之外的所有对象
inactive_entries = MyModel.objects.exclude(is_active=True)for entry in inactive_entries:print(entry)
  • MyModel.objects.exclude(is_active=True): 使用exclude方法排除字段is_active值为True的对象。
获取单个对象
# 获取主键为1的单个对象
try:entry = MyModel.objects.get(pk=1)print(entry)
except MyModel.DoesNotExist:print("MyModel with pk=1 does not exist.")
  • MyModel.objects.get(pk=1): 获取主键(Primary Key)为1的对象。
  • try...except: 异常处理,防止查询不到对象时抛出DoesNotExist异常。

复杂查询操作

链式查询
# 获取is_active为True且name以'D'开头的所有对象
filtered_entries = MyModel.objects.filter(is_active=True).filter(name__startswith='D')for entry in filtered_entries:print(entry)
  • filter(is_active=True).filter(name__startswith='D'): 链式调用filter方法来组合筛选条件。
Q对象复杂查询
from django.db.models import Q# 获取is_active为True或者name以'D'开头的所有对象
complex_entries = MyModel.objects.filter(Q(is_active=True) | Q(name__startswith='D'))for entry in complex_entries:print(entry)
  • from django.db.models import Q: 导入Q对象。
  • Q(is_active=True) | Q(name__startswith='D'): 使用Q对象结合逻辑运算符|(或)构建复杂查询。
跨关联关系查询

假设MyModel有一个外键ForeignKey指向另一个模型RelatedModel

# 获取MyModel的所有对象,其关联的RelatedModel对象的name为'Sample'
related_entries = MyModel.objects.filter(relatedmodel__name='Sample')for entry in related_entries:print(entry)
  • relatedmodel__name='Sample': 使用双下划线__跨关联关系查询RelatedModelname字段。
聚合与分组查询
from django.db.models import Count# 对MyModel对象按is_active字段进行分组,并计算每组的数量
grouped_entries = MyModel.objects.values('is_active').annotate(count=Count('id'))for entry in grouped_entries:print(f"Active: {entry['is_active']}, Count: {entry['count']}")
  • from django.db.models import Count: 导入Count聚合函数。
  • values('is_active').annotate(count=Count('id')): 使用values方法分组并使用annotate进行聚合,计算每组的数量。

性能优化查询

选择性字段查询
# 仅获取MyModel对象的id和name字段
partial_entries = MyModel.objects.only('id', 'name')for entry in partial_entries:print(entry.id, entry.name)
  • MyModel.objects.only('id', 'name'): 使用only方法来限制查询只返回特定字段。
延迟字段查询
# 在需要时才查询MyModel对象的description字段
deferred_entries = MyModel.objects.defer('description')for entry in deferred_entries:print(entry.description)  # 这里才会实际查询description字段
  • MyModel.objects.defer('description'): 使用defer方法延迟加载指定字段,直到实际访问该字段时才会执行查询。
使用select_related优化关联对象查询

假设MyModel有一个外键ForeignKey指向另一个模型RelatedModel

# 通过select_related获取MyModel和其关联的RelatedModel对象
entries_with_related = MyModel.objects.select_related('relatedmodel')for entry in entries_with_related:print(entry.relatedmodel)
  • MyModel.objects.select_related('relatedmodel'): 使用select_related方法来优化对关联对象的查询,减少数据库的查询次数。
使用prefetch_related优化多对多和反向关联查询

假设MyModelOtherModel有多对多关系。

# 通过prefetch_related获取MyModel及其多对多关联的OtherModel对象
entries_with_others = MyModel.objects.prefetch_related('othermodel_set')for entry in entries_with_others:for other in entry.othermodel_set.all():print(other)
  • MyModel.objects.prefetch_related('othermodel_set'): 使用prefetch_related方法来优化多对多和反向关联查询。

赶紧存一下吧!

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

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

相关文章

.NET中的matplotlib平替,ScottPlot简单使用

文章目录 前言解决方案Python调用.NET 原生解决 ScottPlot找到文章ScottPlot Nuget安装简单代码测试代码跑不了5.0新版本测试 总结 前言 我之前在学OpenCV 三语言开发的时候,遇到了一个问题,怎么可视化的显示数据。Python有matplotlib,那么C…

Tomcat的安装及配置教程

文章目录 一、Tomcat二、安装流程三、常见问题四、相关文章 一、Tomcat Tomcat是一个开源的Java Servlet容器,它实现了Java Servlet和JavaServer Pages(JSP)规范,并为Java Web应用程序提供Web服务器环境。以下是Tomcat的一些详细…

量化交易学习2(因子研究)

因子有效性检验 参考1 参考2 在多因子研究框架中,因子的有效性检验是不可避免的工作,其本质是衡量一个因子的选股能力。 目前学术界和业界普遍使用的两种方法: 相关性检验 因子的相关性检验即检验单因子和收益率之间是否存在相关性 IC值 计…

20240126请问在ubuntu20.04.6下让GTX1080显卡让whisper工作在large模式下?

20240126请问在ubuntu20.04.6下让GTX1080显卡让whisper工作在large模式下? 2024/1/26 21:19 问GTX1080模式使用large该如何配置呢? 这个问题没有完成,可能需要使用使用显存更大的显卡了! 比如GTX1080Ti 11GB,更猛的可…

C++(Qt)软件调试---静态分析工具clang-tidy(18)

C(Qt)软件调试—静态分析工具clang-tidy(18) 文章目录 C(Qt)软件调试---静态分析工具clang-tidy(18)1、概述2、clang-tidy基本用法3、目前已有检查项4、Qt Creator中安装clang-tidy5、Qt Creator中使用clang-tidy6、Clang-Tidy配置…

HTML5 服务器发送事件(Server-Sent Events)

前言: 文章内容参考: HTML5 服务器发送事件(Server-Sent Events) | 菜鸟教程 microsoft/fetch-event-source - npm event-source-polyfill - npm 正文: HTML5服务器发送事件(server-sent event)允许网页获得来自服务器…

websocket 通信协议

websocket是什么 答: 它是一种网络通信协议,是 HTML5 开始提供的一种在单个 TCP 连接上进行全双工通讯的协议。 意思就是服务器可以主动向客户端推送信息,客户端也可以主动向服务器发送信息 属于服务器推送技术的一种. 为什么需要websocket? 疑问?…

Windows Server Nginx 反向代理Spring Boot配置无效 404 未找到

一个Spring Boot的系统,开发完成发布到Windows服务器里,使用nginx作为反向代理,修改刷新配置文件,nginx.conf,总是报错404。 这个是不生效刷新配置文件的bat脚本: REM 切换到NGINX安装目录 cd D:\nginx-1.…

修复WordPress内部服务器错误的步骤及解决方案

WordPress是一款广泛使用的开源内容管理系统,但在使用过程中,可能会遇到各种内部服务器错误。这些错误可能由于多种原因引起,例如插件冲突、文件权限问题、服务器配置不当等。为了帮助您快速解决这些问题,本文将为您提供一套详细的…

数据结构排序算详解(动态图+代码描述)

目录 1、直接插入排序(升序) 2、希尔排序(升序) 3、选择排序(升序) 方式一(一个指针) 方式二(两个指针) 4、堆排序(升序) 5、冒…

Golang协程池ants使用笔记

最近工程中遇到goroutine滥用导致的bug,采用了ants协程池来解决。 github-ants官方源码和使用说明。 记录一个例子 package mainimport ("fmt""runtime""github.com/panjf2000/ants/v2" )// 模拟一个任务:求数字x的平方 …

代码随想录算法训练营数组总结

一、理论基础 定义:数组是存放在连续内存空间上的相同类型数据的集合。 注意事项: ①数组下标从0开始。 ②数组元素不能删除,只能覆盖。 ③二维数组的地址空间不一定是连续的。 二、方法总结 1.二分法 思想:设置left、right指针&a…

equence to Sequence Learning with Neural Networks 导读

本文介绍了一种基于深度神经网络(DNN)的序列到序列学习方法,该方法使用多层长短时记忆网络(LSTM)将输入序列映射为固定维度向量,并使用另一个深LSTM解码目标序列。在英语到法语翻译任务上,该方法…

QtRVSim(二)一个 RISC-V 程序的解码流程

继上一篇文章简单代码分析后,本文主要调研如何实现对指令的解析运行。 调试配置 使用 gdb 工具跟踪调试运行。 c_cpp_properties.json 项目配置: {"name": "QtRvSim","includePath": ["${workspaceFolder}/**&quo…

【微调大模型】如何利用开源大模型,微调出一个自己大模型

在人工智能的浪潮中,深度学习已经成为了最炙手可热的技术。其中,预训练大模型如Transformer、BERT等,凭借其强大的表示能力和泛化能力,在自然语言处理、计算机视觉等多个领域取得了显著的成功。然而,这些预训练大模型往往需要巨大的计算资源和时间成本,对于一般的研究者或…

Spring5系列学习文章分享---第五篇(事务概念+特性+案例+注解声明式事务管理+参数详解 )

目录 事务事务概念什么是事务事务四个特性(ACID) 搭建事务操作环境Spring 事务管理介绍注解声明式事务管理声明式事务管理参数配置XML 声明式事务管理事务操作(完全注解声明式事务管理)感谢阅读 开篇: 欢迎再次来到 Spring 5 学习…

Lowest Common Ancestor

模板 1. Tarjan 一个讲的很好的视频:D10 Tarjan算法 P3379【模板】最近公共祖先(LCA)_哔哩哔哩_bilibili,董晓算法出品。 Tarjan总体来说可以概括为: 记录访达:记录某个节点是否已经访问过,防…

3. MATLAB中Plot绘制放大特定的区域

在MATLAB中,我们经常需要绘制图形并进行一些自定义的操作。在本示例中,我们将演示如何在MATLAB中绘制一个图形,并通过放大某个特定的区域来突出显示。 ## 原始图形 首先,我们绘制了一个包含正弦和余弦函数的图形。 % MATLAB 代…

RabbitMQ 笔记二

1.Spring 整合RabbitMQ 生产者消费者 创建生产者工程添加依赖配置整合编写代码发送消息 创建消费者工程添加依赖配置整合编写消息监听器 2.创建工程RabbitMQ Producers spring-rabbitmq-producers <?xml version"1.0" encoding"UTF-8"?> <pr…

【计算机图形学】实验五 一个简单的交互式绘图系统(实验报告分析+截图+源码)

可以先看一看这篇呀~【计算机图形学】专栏前言-CSDN博客https://blog.csdn.net/m0_55931547/article/details/135863062 目录 一、实验目的 二、实验内容