【Django】执行查询—检索对象
检索对象
以下述模型为基础,讨论检索对象的方式方法:
from datetime import datefrom django.db import modelsclass Blog(models.Model):name = models.CharField(max_length=100)tagline = models.TextField()def __str__(self):return self.nameclass Author(models.Model):name = models.CharField(max_length=200)email = models.EmailField()def __str__(self):return self.nameclass Entry(models.Model):blog = models.ForeignKey(Blog, on_delete=models.CASCADE)headline = models.CharField(max_length=255)body_text = models.TextField()pub_date = models.DateField()mod_date = models.DateField(default=date.today)authors = models.ManyToManyField(Author)number_of_comments = models.IntegerField(default=0)number_of_pingbacks = models.IntegerField(default=0)rating = models.IntegerField(default=5)def __str__(self):return self.headline
检索全部对象
>>> all_entries = Entry.objects.all()
通过过滤器检索指定对象
通过添加过滤条件精炼原始 QuerySet。两种最常见的精炼 QuerySet 的方式是:
filter(**kwargs)
返回一个新的 QuerySet,包含的对象满足给定查询参数。
exclude(**kwargs)
返回一个新的 QuerySet,包含的对象 不 满足给定查询参数。
由此可见,对 QuerySet 进行细化的结果本身也是一个 QuerySet,因此可以将细化操作链接在一起。
QuerySets 是惰性的 —— 创建 QuerySet 的过程不涉及任何数据库活动。你可以一直堆叠过滤条件,但 Django 实际上不会运行查询,直到 QuerySet 被评估。
检索单个对象
>>> one_entry = Entry.objects.get(pk=1)
QuerySet条目数限制
QuerySet是一个对象列表,因此类似python数组切片,可以对条目数进行限制,但是也有区别,不支持负索引。
通常对 QuerySet 进行切片会返回一个新的 QuerySet,它不会评估查询。但是如果使用了 Python 切片语法的 “step” 参数,会实际执行查询。
例子:
# 返回前5个对象(对应SQL:LIMIT 5)
>>> Entry.objects.all()[:5]
# 返回第六到第十个对象(对应SQL:OFFSET 5 LIMIT 5)
>>> Entry.objects.all()[5:10]# 不支持负索引,如 Entry.objects.all()[-1]# 返回前10个对象中的第2、4、6、8、10个对象
>>> Entry.objects.all()[:10:2]
字段查询
字段查询即你如何制定 SQL WHERE 子句。它们以关键字参数的形式传递给 QuerySet 方法 filter(), exclude() 和 get()。
基本的查找关键字参数采用形式 field__lookuptype=value (使用双下划线,前面是字段名,后面是查询方式参数,查询ForeignKey时可以使用外键字段名_id)。
例子:
>>> Entry.objects.filter(pub_date__lte="2006-01-01")
查询方式参数有:exact,iexact,contains,icontains,startswith,endswith等等
跨关系查询
为了跨越关系,跨模型使用关联字段名,字段名由双下划线分割,直到拿到想要的字段。
例子:
# 检索所有具有 name 为 'Beatles Blog' 的 Blog 的 Entry 对象
>>> Entry.objects.filter(blog__name="Beatles Blog")
也可反向查询:
# 检索所有至少有一个 headline 包含 'Lennon' 的 Entry 的 Blog 对象
>>> Blog.objects.filter(entry__headline__contains="Lennon")
相关文章:
【Django】执行查询—检索对象
检索对象 以下述模型为基础,讨论检索对象的方式方法: from datetime import datefrom django.db import modelsclass Blog(models.Model):name models.CharField(max_length100)tagline models.TextField()def __str__(self):return self.nameclass …...
Python:练习:编写一个程序,写入一个美金数量,然后显示出如何用最少的20美元、10美元、5美元和1美元来付款
案例: python编写一个程序,写入一个美金数量,然后显示出如何用最少的20美元、10美元、5美元和1美元来付款: Enter a dollar amout:93 $20 bills: 4 $10 bills: 1 $5 bills:0 $1 bills:3 思考: 写入一个美金数量&…...
模板方法模式 详解 设计模式
模板方法模式 模板方法模式是一种行为型设计模式,它定义了一个算法的骨架,将一些步骤延迟到子类中实现。这种模式允许子类在不改变算法结构的情况下重新定义算法的某些步骤。 结构 抽象类(Abstract Class):负责给出一…...
Node.js_基础知识(http模块)
网络基础 URL的组成结构:协议名: // 主机名 [:端口号] [/路径] [?查询字符串]协议默认端口: http:80,开发常用端口有 3000、8080、8090、9000https: 443 如果端口被其他程序占用,可以使用 资源监视器 找到占用端口的…...
matlab工具包
matlab安装yalmip和cplex出错 - 知乎 (zhihu.com) Cplex的安装和使用实例-CSDN博客 一条龙教程:Matlab下使用yalmip(工具箱)cplex(求解器)_使用yalmip和cplex求解器进行建模和求解的步骤如下:-CSDN博客 啊啊啊,好开心ÿ…...
UCSF DOCK 分子对接详细案例(01)- rigid, fixed anchor, flexible dock
欢迎浏览我的CSND博客! Blockbuater_drug …点击进入 文章目录 前言一、操作环境二、研究背景三、受体-配体结构文件准备3.1准备文件夹DOCK_workdir, 下载晶体结构3.1.1 来自湿实验的受体配体共晶结构:3.1.2 来自深度学习和语言模型推理预测的蛋白结构&a…...
java基础(4)注解,集合,
注解 什么是注解(Annotation)?注解是放在Java源码的类、方法、字段、参数前的一种特殊“注释” // this is a component: Resource("hello") public class Hello {Injectint n;PostConstructpublic void hello(Param String name…...
基于springboot+vue的大学城水电管理系统(前后端分离)
博主主页:猫头鹰源码 博主简介:Java领域优质创作者、CSDN博客专家、阿里云专家博主、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战,欢迎高校老师\讲师\同行交流合作 主要内容:毕业设计(Javaweb项目|小程序|Pyt…...
代码随想录算法训练营第四十六天| 139.单词拆分、卡码网第56题
代码随想录算法训练营第四十六天| 139.单词拆分、卡码网第56题 139.单词拆分卡码网第56题 139.单词拆分 题目链接 文章讲解 class Solution { public:bool wordBreak(string s, vector<string>& wordDict) {int bagSize s.size(), n wordDict.size();vector<boo…...
Redis 在 Linux 系统下安装部署的两种方式详细说明
小伙伴们好,欢迎关注,一起学习,无限进步 Redis安装和配置 1、首先在官网下载好redis-6.0.9.tar.gzhttp://redis.io/ 或者使用 wget 命令下载:wget http://download.redis.io/releases/redis-6.0.9.tar.gz 2、下载使用上传到阿里…...
【茶话数据结构】查找最短路径——Dijkstra算法详解(保姆式详细图解,步步紧逼,保你学会)
💯 博客内容:【茶话数据结构】查找最短路径——Dijkstra算法详解 😀 作 者:陈大大陈 🦉所属专栏:数据结构笔记 🚀 个人简介:一个正在努力学技术的准前端,专注基础和实…...
Webserver解决segmentation fault(core dump)段错问问题
前言 在完成了整个项目后,我用make命令编译了server,当我运行./server文件时,出现了段错误 在大量的代码中找出错因并不是一件容易的事,尤其是对新手程序员来说。而寻找bug的过程就像是侦探调查线索追查凶手一样,我们…...
存储过程基本了解
文章目录 介绍存储过程示例1. 目的2. 输入参数3. 输出参数4. 执行逻辑5. 返回值6. 示例用法7. 注意事项 存储过程的关键字有哪些简单实操 介绍 存储过程是一组预编译的SQL语句,以及流程控制语句,封装在数据库服务器中并可以被重复调用。它们可以接收参数…...
『大模型笔记』RAG应用的12种调优策略指南
RAG应用的12种调优策略指南 文章目录 一. 概要二. 数据索引2.1. 数据清洗2.2. 分块2.3. 嵌入模型2.4. 元数据(或未向量化的数据)2.5. 多索引2.6. 索引算法三. 推理阶段(检索和生成)3.1. 检索参数3.2. 高级检索策略3.3. 重新排序模型3.5. 大语言模型(LLM)...
leedcode刷题--day7(字符串)
23 文章讲解 力扣地址 C class Solution { public:void reverseString(vector<char>& s) {int left 0;int right s.size() - 1; // right 应该初始化为 s.size() - 1while (left < right) {swap(s[left], s[right]); // 直接交换 s[left] 和 s[right] 的值lef…...
【蓝桥杯省赛真题31】python连续正整数之和 中小学青少年组蓝桥杯比赛python编程省赛真题解析
目录 python连续正整数之和 一、题目要求 1、编程实现 2、输入输出 二、算法分析 三、程序编写 四、程序说明 五、运行结果 六、考点分析 七、 推荐资料 1、蓝桥杯比赛 2、考级资料 3、其它资料 python连续正整数之和 第十二届蓝桥杯青少年组python比赛省赛真题 …...
【116个】网络安全测试相关面试真题
1、Burpsuite常用的功能是什么? 2、reverse_tcp和bind_tcp的区别? 3、拿到一个待检测的站或给你一个网站,你觉得应该先做什么? 4、你在渗透测试过程中是如何敏感信息收集的? 5、你平时去哪些网站进行学习、挖漏洞提…...
微服务day02-Ribbon负载均衡与Nacos安装与入门
一.Ribbon负载均衡 在上一节中,我们通过在RestTemplte实例中加上了注解 LoadBalanced,表示将来由RestTemplate发起的请求会被Ribbon拦截和处理,实现了访问服务时的负载均衡,那么他是如何实现的呢? 1.1 Ribbon负载均衡的原理 Rib…...
深度学习-神经网络原理
文章目录 神经网络原理1.单层神经网络1.1 回归单层神经网络:线性回归1.2 二分类单层神经网络:sigmoid与阶跃函数 1.3 多分类单层神经网络:softmax回归 神经网络原理 人工神经网络(Artificial Neural Network,ANN&…...
Chat GPT:智能对话的下一步
Chat GPT:智能对话的下一步 介绍 Chat GPT(Generative Pre-trained Transformer)是一种基于Transformer架构的强大对话模型,可以产生自然流畅的回答,并实现人机对话的感觉。本文将探讨Chat GPT在智能对话领域的影响和…...
2015年的一个RFC草案,如何终结了“证书到期导致网站崩溃“的深夜急救时代
我们在HTTPS还没全面普及的前十年,互联网运维圈里流传着一句特别扎心的黑色玩笑:“再稳定的网站,也逃不过证书过期的午夜惊魂”。相信不少运维人都有过这样的经历——凌晨睡得正沉,突然被监控告警吵醒,迷迷糊糊地爬起来…...
DeOldify GPU算力优化教程:显存占用控制与推理速度提升技巧
DeOldify GPU算力优化教程:显存占用控制与推理速度提升技巧 1. 项目简介与优化价值 DeOldify是一个基于深度学习技术的黑白图像上色工具,它使用U-Net架构结合ResNet编码器来实现高质量的图像色彩还原。虽然这个工具使用起来很简单,但在实际…...
从水处理到工控安全:WADI数据集在异常检测中的独特价值与应用场景解析
WADI数据集:工业控制系统异常检测的黄金标准与实践指南 工业控制系统(ICS)的安全防护一直是关键基础设施保护的核心议题。想象一下,一座城市的供水系统突然遭到网络攻击,导致水质异常或供水中断——这不仅会造成经济损失,更直接威…...
敏捷协同工具选哪家?2026 年 6 大 Scrum 与 Kanban 工具测评
本文将深入对比6大敏捷协同平台:PingCode、Worktile、伙伴云、板栗看板、猪齿鱼、JNPF 在 2026 年,敏捷开发已不再局限于 IT 行业,各行各业都在追求高效协同。但面对市面上琳琅满目的敏捷协同平台,企业管理者常陷入纠结࿱…...
vLLM-v0.17.1惊艳效果:AWQ量化后Llama3-8B显存占用降至11GB
vLLM-v0.17.1惊艳效果:AWQ量化后Llama3-8B显存占用降至11GB 1. vLLM框架简介 vLLM是一个专为大型语言模型(LLM)设计的高性能推理和服务库,以其出色的速度和易用性著称。这个项目最初由加州大学伯克利分校的天空计算实验室开发,现在已经发展…...
为什么92%的AIAgent项目卡在世界建模阶段?深度拆解6个被忽略的感知-记忆-推理对齐断点
第一章:世界模型在AIAgent架构中的核心定位与失败率归因 2026奇点智能技术大会(https://ml-summit.org) 世界模型(World Model)并非AIAgent的可选组件,而是其认知闭环的底层基础设施——它承担着环境建模、状态推演、反事实规划与…...
苍穹外卖-day05-Redis的入门知识点学习笔记
苍穹外卖-day05-Redis的入门知识点学习笔记 【作者说:我作为一个初学者,也是初次整理关于Redis的入门知识点内容,我也是比较细致的了解这些具体内容,在项目中有很多用到redis的具体环境,例如高并发,热点等&…...
【AIAgent医疗诊断合规生死线】:2026奇点大会首次公开NMPA+GDPR双轨适配清单(含12项必须审计项)
第一章:2026奇点智能技术大会:AIAgent医疗诊断 2026奇点智能技术大会(https://ml-summit.org) 临床场景驱动的多模态Agent架构 本届大会首次公开展示了基于LLM-Oriented Agent(LOA)范式的医疗诊断系统MediChain,该系…...
保姆级教程:在Windows上快速搭建Prosys OPC UA模拟服务器,并用Neuron采集测试数据
从零搭建OPC UA测试环境:Prosys与Neuron实战指南 工业物联网领域的数据采集离不开OPC UA协议的支持,但对于刚接触这一技术的开发者来说,如何快速搭建本地测试环境往往是个令人头疼的问题。本文将手把手带你完成从Prosys OPC UA模拟服务器配置…...
014集——CSV格式坐标批量导入CAD图纸(C#二次开发高效技巧)
1. CSV坐标批量导入CAD的实战价值 每次遇到需要把几百个坐标点画到CAD图纸的情况,你是不是还在手动一个个输入?我在某次水利工程测绘项目中,就亲眼见过同事对着纸质表格敲了整整两天坐标。其实用C#二次开发配合CSV文件,20秒就能搞…...
