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

django orm增删改查操作

1. 基本操作

1.1 创建对象

可以通过 Django ORM 来创建数据库中的记录。

示例:

# 方法1:先创建对象,再保存
person = Person(name='Alice', age=30, email='alice@example.com')
person.save()# 方法2:直接创建
person = Person.objects.create(name='Bob', age=25, email='bob@example.com')
1.2 查询数据

ORM 提供了丰富的查询接口,通过模型类的 objects 管理器进行查询。

查询所有记录:

people = Person.objects.all()  # 返回所有记录的 QuerySet

根据条件查询:

# 查找name为'Alice'的记录
person = Person.objects.get(name='Alice')# 过滤出age大于30的所有人
older_people = Person.objects.filter(age__gt=30)

查询结果排序:

# 按年龄升序排序
people = Person.objects.all().order_by('age')
1.3 更新数据

方式1:

person = Person.objects.get(name='Alice')
person.age = 31  # 修改属性
person.save()  # 保存修改

方式2(批量更新):

Person.objects.filter(name='Bob').update(age=26)
1.4 删除数据

单个删除:

person = Person.objects.get(name='Alice')
person.delete()

批量删除:

Person.objects.filter(age__lt=20).delete()  # 删除所有年龄小于20的人

2. 进阶操作

2.1 关联查询(外键、ManyToMany)

Django ORM 支持表与表之间的关联关系,如 ForeignKey(外键)和 ManyToManyField(多对多)。

示例:定义外键关联

class Group(models.Model):name = models.CharField(max_length=100)class Person(models.Model):name = models.CharField(max_length=100)group = models.ForeignKey(Group, on_delete=models.CASCADE)  # 外键关联

通过 ORM 可以轻松进行关联查询:

# 查找属于某个组的所有人
group = Group.objects.get(name='Developers')
people_in_group = group.person_set.all()  # 获取关联的所有 Person 对象
2.2 事务支持

Django ORM 支持事务管理,保证多个数据库操作的原子性。

示例:

from django.db import transactionwith transaction.atomic():person1 = Person.objects.create(name='Charlie', age=22)person2 = Person.objects.create(name='Dave', age=28)# 如果其中一个操作失败,另一个也会回滚
2.3 聚合查询

Django ORM 支持聚合查询,例如求和、平均值、最大值等。

示例:

from django.db.models import Avg, Max# 计算所有人的平均年龄
average_age = Person.objects.all().aggregate(Avg('age'))# 查找最大年龄
max_age = Person.objects.all().aggregate(Max('age'))

3. 查询优化(具体见“查询优化总结”)

Django ORM 提供了优化查询的方法,比如 select_relatedprefetch_related,用于减少多次数据库访问。

示例:

# 使用 select_related 进行外键优化查询
people = Person.objects.select_related('group').all()

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 从零到一:构建你的第一个AI项目(实战教程)
  • 【算法】差分思想:强大的算法技巧
  • Parallels Desktop 20 for Mac中文版发布了?会哪些新功能
  • uniapp 做一个查看图片的组件,图片可缩放移动
  • 基于C++的成绩管理系统
  • 828华为云征文 | 使用Flexus云服务器X实例部署GLPI资产管理系统
  • 基于python+django+vue的外卖管理系统
  • 【python设计模式1】面向对象设计原则
  • 基于springboot+vue+uniapp的驾校报名小程序
  • 工厂模式,策略模式,代理模式,单例模式在项目中的应用
  • 大语言模型之ICL(上下文学习) - In-Context Learning Creates Task Vectors
  • 淘宝npm镜像源更新后,如何正常使用npm命令
  • linux下lvm(逻辑卷管理器)
  • WebGL系列教程五(使用索引绘制彩色立方体)
  • 云平台虚机卡顿问题分析
  • 【跃迁之路】【641天】程序员高效学习方法论探索系列(实验阶段398-2018.11.14)...
  • 2017前端实习生面试总结
  • 30秒的PHP代码片段(1)数组 - Array
  • Angular数据绑定机制
  • Apache的80端口被占用以及访问时报错403
  • codis proxy处理流程
  • ES6, React, Redux, Webpack写的一个爬 GitHub 的网页
  • IDEA常用插件整理
  • java中的hashCode
  • JS数组方法汇总
  • js算法-归并排序(merge_sort)
  • Map集合、散列表、红黑树介绍
  • Protobuf3语言指南
  • rc-form之最单纯情况
  • tweak 支持第三方库
  • 力扣(LeetCode)357
  • 前端知识点整理(待续)
  • 驱动程序原理
  • 深度学习入门:10门免费线上课程推荐
  • 突破自己的技术思维
  • 正则表达式
  • - 转 Ext2.0 form使用实例
  • #Js篇:单线程模式同步任务异步任务任务队列事件循环setTimeout() setInterval()
  • (1)Nginx简介和安装教程
  • (CPU/GPU)粒子继承贴图颜色发射
  • (博弈 sg入门)kiki's game -- hdu -- 2147
  • (二)linux使用docker容器运行mysql
  • (十七)Flask之大型项目目录结构示例【二扣蓝图】
  • (实测可用)(3)Git的使用——RT Thread Stdio添加的软件包,github与gitee冲突造成无法上传文件到gitee
  • (一)C语言之入门:使用Visual Studio Community 2022运行hello world
  • (一)u-boot-nand.bin的下载
  • (转)LINQ之路
  • (转)mysql使用Navicat 导出和导入数据库
  • (转载)虚函数剖析
  • ***汇编语言 实验16 编写包含多个功能子程序的中断例程
  • .NET 3.0 Framework已经被添加到WindowUpdate
  • .NET Core工程编译事件$(TargetDir)变量为空引发的思考
  • .NET Micro Framework 4.2 beta 源码探析
  • .NET 解决重复提交问题
  • .net 使用ajax控件后如何调用前端脚本