Django(21)-ORM删除操作及实例演示
  TEZNKK3IfmPf 2023年11月14日 43 0

1、单个数据删除

  • 查找查询结果对应的一个数据对象
  • 调用这个数据对象的delete()删除
    如:
>>> from app1.models import Person
>>> p=Person.objects.filter(name="tom")
>>> p
<QuerySet [<Person: 姓名:tom,年龄:20,性别:man>]>
>>> p.delete()
(1, {
     
       'app1.Person': 1})
>>>

从数据库后台执行查询语句,可以看出已经删除一条数据了,姓名为tom的已经被删除了
Django(21)-ORM删除操作及实例演示

2、批量数据删除

  • 查找查询结果几种满足条件的全部QuerySet查询集合对象
  • 调用查询集合对象的delete()方法实现删除

为了演示批量删除数据,这里先试用如下命令向数据库中增加三条数据

>>> p1=Person(name="a",age=30,sex="man")
>>> p1.save()
>>> p2=Person(name="b",age=34,sex="man")
>>> p2.save()
>>> p3=Person(name="c",age=38,sex="man")
>>> p3.save()

通过数据库后台确认已经增加了三条数据
Django(21)-ORM删除操作及实例演示
下面执行年龄大于等于30的删除

>>> persons=Person.objects.filter(age__gte=30)
>>> persons.delete()
(3, {
     
       'app1.Person': 3})
>>>

然后到数据库后台执行以下查询语句,发现此时刚刚增加的三条数据已经被删除
Django(21)-ORM删除操作及实例演示

3、伪删除

  • 通常不会轻易在业务里把数据真的删除,取而代之的是做伪删除,即在表中增加一个布尔型字段(is_active),默认是True,执行删除时,将欲删除数据的is_active字段设置为False即可
  • 注意:使用伪删除时,确保显示数据的地方,均增加了is_active=True的过滤查询
【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2023年11月14日 0

暂无评论

推荐阅读
  TEZNKK3IfmPf   2024年05月31日   36   0   0 python开发语言
  TEZNKK3IfmPf   2024年05月31日   27   0   0 python
  TEZNKK3IfmPf   2024年05月31日   28   0   0 python
TEZNKK3IfmPf