Django——ORM增删改查

基本对象

model.objects

创建数据

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

python manage.py shell

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

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

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

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

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

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

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

查询操作 

# 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

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
THE END
分享
二维码
< <上一篇
下一篇>>