当前位置: 首页 > news >正文

django的增删改查,排序,分组等常用的ORM操作

Django 的 ORM(对象关系映射)提供了一种方便的方式来与数据库进行交互。

1. Django模型


在 `myapp/models.py` 中定义一个示例模型:```python
from django.db import modelsclass Person(models.Model):name = models.CharField(max_length=100)age = models.IntegerField()city = models.CharField(max_length=100)def __str__(self):return self.name

运行迁移命令来创建数据库表:

python manage.py makemigrations
python manage.py migrate

2. 增 (Create)

创建单个对象
from myapp.models import Person# 创建并保存一个新对象
person = Person(name='Alice', age=25, city='New York')
person.save()
使用 create() 方法
person = Person.objects.create(name='Bob', age=30, city='Los Angeles')

3. 查 (Read)

获取所有对象
people = Person.objects.all()
for person in people:print(person.name, person.age, person.city)
获取单个对象
person = Person.objects.get(id=1)
print(person.name, person.age, person.city)
使用过滤器
# 获取所有年龄大于25的人
people = Person.objects.filter(age__gt=25)
for person in people:print(person.name, person.age, person.city)

4. 改 (Update)

更新单个对象
person = Person.objects.get(id=1)
person.age = 26
person.save()
批量更新
Person.objects.filter(city='New York').update(city='NYC')

5. 删 (Delete)

删除单个对象
person = Person.objects.get(id=1)
person.delete()
批量删除
Person.objects.filter(age__lt=20).delete()

6. 排序 (Ordering)

按单个字段排序
people = Person.objects.all().order_by('age')
for person in people:print(person.name, person.age, person.city)
按多个字段排序
people = Person.objects.all().order_by('city', '-age')
for person in people:print(person.name, person.age, person.city)

7. 分组 (Grouping)

Django ORM 不直接支持分组操作,但可以使用 annotateaggregate 方法来实现类似的功能。

使用 annotate 进行分组计数
from django.db.models import Count# 按城市分组并计数
city_counts = Person.objects.values('city').annotate(count=Count('id'))
for city_count in city_counts:print(city_count['city'], city_count['count'])
使用 aggregate 进行聚合操作
from django.db.models import Avg, Max, Min# 计算平均年龄
average_age = Person.objects.aggregate(Avg('age'))
print(average_age)  # 输出: {'age__avg': 27.5}# 计算最大和最小年龄
age_stats = Person.objects.aggregate(Max('age'), Min('age'))
print(age_stats)  # 输出: {'age__max': 30, 'age__min': 25}

8. 复杂查询

Q 对象进行复杂查询
from django.db.models import Q# 获取年龄大于25或城市为'New York'的人
people = Person.objects.filter(Q(age__gt=25) | Q(city='New York'))
for person in people:print(person.name, person.age, person.city)
F 对象进行字段间比较
from django.db.models import F# 获取年龄大于等于城市长度的人
people = Person.objects.filter(age__gte=F('city__length'))
for person in people:print(person.name)

相关文章:

django的增删改查,排序,分组等常用的ORM操作

Django 的 ORM(对象关系映射)提供了一种方便的方式来与数据库进行交互。 1. Django模型 在 myapp/models.py 中定义一个示例模型:python from django.db import modelsclass Person(models.Model):name models.CharField(max_length100)age…...

Leetcode Java学习记录——树、二叉树、二叉搜索树

文章目录 树的定义树的遍历中序遍历代码 二叉搜索树 常见二维数据结构:树/图 树和图的区别就在于有没有环。 树的定义 public class TreeNode{public int val;public TreeNode left,right;public TreeNode(int val){this.val val;this.left null;this.right nu…...

华为HCIP Datacom H12-821 卷30

1.单选题 以下关于OSPF协议报文说法错误的是? A、OSPF报文采用UDP报文封装并且端口号是89 B、OSPF所有报文的头部格式相同 C、OSPF协议使用五种报文完成路由信息的传递 D、OSPF所有报文头部都携带了Router-ID字段 正确答案:A 解析: OSPF用IP报文直接封装协议报文,…...

element el-table实现表格动态增加/删除/编辑表格行,带校验规则

本篇文章记录el-table增加一行可编辑的数据列,进行增删改。 1.增加空白行 直接在页面mounted时对form里面的table列表增加一行数据,直接使用push() 方法增加一列数据这个时候也可以设置一些默认值。比如案例里面的 产品件数 。 mounted() {this.$nextTi…...

QT调节屏幕亮度

1、目标 利用QT实现调节屏幕亮度功能:在无屏幕无触控时,将屏幕亮度调低,若有触控则调到最亮。 2、调节亮度命令 目标装置使用嵌入式Linux系统,调节屏幕亮度的指令为: echo x > /sys/class/backlight/backlight/…...

实变函数精解【3】

文章目录 点集求导集 闭集参考文献 点集 求导集 例1 E { 1 / n 1 / m : n , m ∈ N } 1. lim ⁡ n → ∞ ( 1 / n 1 / m ) 1 / m 2. lim ⁡ n , m → ∞ ( 1 / n 1 / m ) 0 3. E ′ { 0 , 1 , 1 / 2 , 1 / 3 , . . . . } E\{1/n1/m:n,m \in N\} \\1.\lim_{n \rightar…...

JVM:SpringBoot TomcatEmbeddedWebappClassLoader

文章目录 一、介绍二、SpringBoot中TomcatEmbeddedWebappClassLoader与LaunchedURLClassLoader的关系 一、介绍 TomcatEmbeddedWebappClassLoader 是 Spring Boot 在其内嵌 Tomcat 容器中使用的一个类加载器(ClassLoader)。在 Spring Boot 应用中&#…...

蜂窝互联网接入:连接世界的无缝体验

通过Wi—Fi,人们可以方便地接入互联网,但无线局域网的覆盖范围通常只有10~100m。当我们携带笔记本电脑在外面四处移动时,并不是在所有地方都能找到可接入互联网的Wi—Fi热点,这时候蜂窝移动通信系统可以为我们提供广域…...

Sprint Boot 2 核心功能(一)

核心功能 1、配置文件 application.properties 同基础入门篇的application.properties用法一样 Spring Boot 2 入门基础 application.yaml(或application.yml) 基本语法 key: value;kv之间有空格大小写敏感使用缩进表示层级关系缩进不允…...

GitLab CI/CD实现项目自动化部署

1 GitLab CI/CD介绍 GitLab CI/CD 是 GitLab 中集成的一套用于软件开发的持续集成(Continuous Integration)、持续交付(Continuous Delivery)和持续部署(Continuous Deployment)工具。这套系统允许开发团队…...

阿里云调整全球布局关停澳洲云服务器,澳洲服务器市场如何选择稳定可靠的云服务?

近日,阿里云宣布将关停澳大利亚地域的数据中心服务,这一决定引发了全球云计算行业的广泛关注。作为阿里云的重要海外市场之一,澳洲的数据中心下架对于当地的企业和个人用户来说无疑是一个不小的挑战。那么,在阿里云调整全球布局的…...

排序(二)——快速排序(QuickSort)

欢迎来到繁星的CSDN,本期内容包括快速排序(QuickSort)的递归版本和非递归版本以及优化。 一、快速排序的来历 快速排序又称Hoare排序,由霍尔 (Sir Charles Antony Richard Hoare) ,一位英国计算机科学家发明。霍尔本人是在发现冒泡排序不够快…...

<数据集>穿越火线cf人物识别数据集<目标检测>

数据集格式:VOCYOLO格式 图片数量:3440张 标注数量(xml文件个数):3440 标注数量(txt文件个数):3440 标注类别数:1 标注类别名称:[person] 使用标注工具:labelImg 标注规则:对…...

a+=1和a=a+1的区别

文章目录 a1 和a a1的区别一、实例代码二、代码解释三、总结 a1 和a a1的区别 一、实例代码 public class Test {public static void main(String[] args) {byte a 10; // a a 1; // a (byte) (a 1);a 1;System.out.println(a);} }上面的对变量a进行加一操作时&a…...

设计模式使用场景实现示例及优缺点(结构型模式——桥接模式)

结构型模式 桥接模式(Bridge Pattern) 桥接模式(Bridge Pattern)是一种结构型设计模式,其主要目的是“将抽象与实现解耦,使得两者可以独立地变化”。这种模式通过提供抽象化和实现化之间的桥接结构&#…...

Spring——自动装配Bean

自动装配是Spring满足bean依赖的一种方式 Spring会在上下文中自动寻找,并自动给bean装配属性 在Spring中有三种装配的方式: 1. 在xml中显示配置 2. 在java中显示配置 3. 隐式的自动装配bean【重要】 测试 记得创建Cat、Dog、People类 public clas…...

云端典藏:iCloud中个人收藏品目录的智能存储方案

云端典藏:iCloud中个人收藏品目录的智能存储方案 在数字化生活不断推进的今天,个人收藏品的管理也趋向于电子化和云端化。iCloud作为苹果公司提供的云服务,为个人收藏品目录的存储和管理提供了一个安全、便捷、跨设备的解决方案。本文将详细…...

安全开发基础篇-数据溢出

上一节我们简单讲解了多语言的数据类型,我们只需要知道这个概念,并且在不同语言有不同的规矩就好。这节讲数据溢出,严格说应该是字符串溢出和整数溢出。 在软件开发中,字符串和整数溢出漏洞是常见的安全问题,它们可能…...

Scanner工具类

扫描控制台输入 1.nextLine nextLine() 方法会扫描输入流中的字符,直到遇到行末尾的换行符 \n,然后将该行的内容作为字符串返回,同时,nextLine() 会将 Scanner 对象的位置移动到下一行的开头,以便下一次读取数据时从下…...

springboot3 集成GraalVM

目录 安装GraalVM 配置环境变量 Pom.xml 配置 build包 测试 安装GraalVM Download GraalVM 版本和JDK需要自己选择 配置环境变量 Jave_home 和 path 设置setting.xml <profile><id>graalvm-ce-dev</id><repositories><repository><id&…...

2026届必备的六大AI写作神器解析与推荐

Ai论文网站排名&#xff08;开题报告、文献综述、降aigc率、降重综合对比&#xff09; TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 当下&#xff0c;鉴于人工智能生成内容&#xff08;AIGC&#xff09;技术越来越普及&#x…...

手势识别技术全解析:从光学、雷达到IoT集成的实战指南

1. 项目概述&#xff1a;从“看见”到“看懂”&#xff0c;手势交互的破局点最近在跟进一个智能家居的集成项目&#xff0c;客户提了个挺有意思的需求&#xff1a;能不能让家里的灯、空调、窗帘&#xff0c;不用说话&#xff0c;也不用找手机&#xff0c;就靠“挥挥手”来控制&…...

AI智能体技能开发实战:从awesome-agent-skills到高效智能体构建

1. 项目概述&#xff1a;从技能清单到智能体构建的实战指南最近在折腾AI智能体&#xff08;Agent&#xff09;开发的朋友&#xff0c;估计都绕不开一个名字&#xff1a;awesome-agent-skills。这个由VoltAgent维护的开源项目&#xff0c;乍一看就是个GitHub上常见的“Awesome”…...

图像边缘检测避坑指南:用Python调参时,Sobel和Laplacian的那些‘坑’你踩过吗?

图像边缘检测实战避坑手册&#xff1a;从Sobel到Laplacian的调参艺术 边缘检测是计算机视觉中最基础却最易翻车的操作之一。第一次用OpenCV实现Sobel算子时&#xff0c;我盯着屏幕上那些断裂的边缘和噪点陷入沉思——为什么教科书上的示例如此完美&#xff0c;而我的代码却像被…...

基于RT-Thread与N32G457的工业UART网关设计与实现

1. 项目概述与核心价值最近在做一个工业数据采集的项目&#xff0c;现场有十几台不同品牌、不同协议的串口设备&#xff0c;PLC、仪表、传感器什么都有&#xff0c;它们的数据都需要汇总到一台中心服务器上。最头疼的是&#xff0c;这些设备分布在车间各处&#xff0c;拉线成本…...

RT-Thread Nano串口控制台移植:GD32F470实现rt_kprintf打印与调试

1. 项目概述与核心目标上次我们成功把 RT-Thread Nano 内核搬到了梁山派 GD32F470 开发板上&#xff0c;让这块高性能的 MCU 跑起了实时任务调度。但光有内核&#xff0c;就像给电脑装好了操作系统却没法敲命令、看输出&#xff0c;调试和交互起来非常别扭。官方 Nano 包的精髓…...

NotebookLM生物技术研究落地难?92%实验室尚未启用的3个隐藏功能(内部白皮书首次公开)

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;NotebookLM生物技术研究落地难&#xff1f;92%实验室尚未启用的3个隐藏功能&#xff08;内部白皮书首次公开&#xff09; NotebookLM 作为 Google 推出的实验性 AI 助手&#xff0c;其在生物技术领域的…...

3个核心优势:重新定义Windows平台Fastboot工具的工作流

3个核心优势&#xff1a;重新定义Windows平台Fastboot工具的工作流 【免费下载链接】FastbootEnhance A user-friendly Fastboot ToolBox & Payload Dumper for Windows 项目地址: https://gitcode.com/gh_mirrors/fa/FastbootEnhance FastbootEnhance是一款专为Win…...

抖音批量下载神器:三步搞定无水印视频下载,告别手动烦恼

抖音批量下载神器&#xff1a;三步搞定无水印视频下载&#xff0c;告别手动烦恼 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser f…...

保姆级教程:在IMX6ULL开发板上手把手实现红外遥控器驱动(基于NEC协议与Linux 5.x内核)

从零构建IMX6ULL红外遥控驱动&#xff1a;NEC协议全解析与Linux 5.x实战指南 当你想在嵌入式设备上实现红外遥控功能时&#xff0c;NEC协议驱动的开发往往是第一个需要攻克的堡垒。本文将带你深入理解红外通信原理&#xff0c;并手把手完成从硬件连接到驱动测试的全流程。不同于…...