Django——ORM增删改查

基本对象

model.objects

创建数据

可以通过django编写的命令行方式快捷创建数据

python manage.py shell

如果对模型层有任何修改都需要重启shell,否则操作容易出错

在shell中我们需要先引入我们的模型,如from bookstore.models import Book

然后通过以下代码创建一条条数据

python 复制代码
# 方法一
book1 = Book.objects.create(title='python',pub='unknown',price=20)

# 此时数据库中就已经有了这样一条数据

#方法二
book2 = Book(title='python',pub='unknown',price=20)

book2.save() # 至此才成功创建book2的数据

查询操作

python 复制代码
# django中 我们每个模型类都对应一个objects属性
# 通过调用该属性可获得该模型的相关操作

# 假设我们已有Book类

# 相当于select * from book;
books = Book.objects.all()

调用的先后顺序不重要,django会自动帮我们按sql逻辑叠加条件执行

返回的对象均为Queryset,这一类对象还可以继续调用django编写的这些方法

如果查询结果为空,返回的就是一个空的Queryset对象

复杂问题情境:现需要查询价格高于20或出版社为清华大学出版社的书

  • 这里需要介绍django中的Q对象

from django.db.models import Q

Books.objects.fillter(Q(price__gt=20)|Q(pub="清华大学出版社"))

Q对象可以支持或(|)非(~)等复杂逻辑操作,只需要在每个条件外包裹Q即可

很有助于我们进行复杂的查询操作

修改操作

①对要操作的对象集合统一修改

  1. 先通过查询操作获取books
  2. 对这个Queryset调用update方法,实现批量修改( books.update(price=100) )

②对要操作的对象集合逐一修改

  1. 先通过查询操作获取books
  2. 通过循环逐一访问属性值,将其修改为目标值
  3. 调用该对象的save方法保存修改结果

③对要操作的对象集合在原有基础上统一增减

这里要用到django的F对象

from django.db.models import F

问题情境一:使书店中所有书在原基础上涨价10元

使用方法:Book.objects.all().update(price=F('price')+10)

即**F('字段名')**可以针对单一对象的字段值进行操作,这样操作的效率将高于访问每一个Book属性值并对其进行修改然后保存的操作

问题情境二:查询书店中所有市场价高于零售价的书

使用方法:books = Book.objects.fillter(market_price__gt(F('price'))

__gt表示的就是大于,在前面的查询操作扩展中有提到

有了F对象后,可以快速实现对同一个对象不同字段比较的结果

删除操作

  • 调用Queryset下的delete方法即可做到完全删除

  • 但实际应用中我们不一定要彻底删除该数据,而是对该数据在查询时隐藏

    这时我们在创建模型时需要一个辅助布尔字段is_active,当执行删除操作时,只需要将该字段设置为False,就能达到删除的目的,但这样操作后,以后任何的查询操作都要增加一个过滤值is_active=True

相关推荐
程序设计实验室4 小时前
不同Django服务器和部署方式的性能调研
django
萧曵 丶4 小时前
Redis 是单线程的吗?
数据库·redis
老邓计算机毕设4 小时前
SSM校园招聘管理系统968b0(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·校园招聘管理系统·简历投递
Zoey的笔记本4 小时前
敏捷与稳定并行:Scrum看板+BPM工具选型指南
大数据·前端·数据库·python·低代码
我是谁的程序员4 小时前
有没有在 iOS 直接抓包 的App?
后端
5***b974 小时前
Spring Boot--@PathVariable、@RequestParam、@RequestBody
java·spring boot·后端
晴天¥5 小时前
Oracle DB 的相关管理工具
数据库·oracle
无限大65 小时前
为什么"算法推荐"这么准?——从协同过滤到深度学习
后端
Codeking__5 小时前
Redis的value类型介绍——set
数据库·redis·缓存
林太白5 小时前
Vite8 Beta来了,Rolldown携手Oxc
前端·javascript·后端