Django(21)-ORM删除操作及实例演示

Django(1)-简介

Django(2)-创建项目及默认项目目录结构介绍

Django(3)-配置文件详解

Django(4)-URL和视图

Django(5)-路由配置实例

Django(6)-请求及响应

Django(7)-Get请求和Post请求

Django(8)-设计模式

Django(9)-模板层简介与入门实例

Django(10)-模板层的变量和标签

Django(11)-模板层的过滤器和继承

Django(12)-url反向解析

Django(13)-静态文件

Django(14)-应用及分布式路由

Django(15)-模型层及ORM介绍

Django(16)-ORM基础字段及选项

Django(17)-ORM创建数据

Django(18)-ORM常用的查询函数详解及实例演示

Django(19)-ORM条件查询

Django(20)-ORM更新操作及实例演示

Django(21)-ORM删除操作及实例演示

Django(22)-ORM中F对象和Q对象

Django(23)-ORM聚合查询和原生数据库操作

Django(24)-admin后台管理设置步骤以及常见样式详解

Django实战技巧(1)-开发测试生产环境配置切换处理技巧

Django实战技巧(2)-git代码仓分支管理技巧

Django实战技巧(3)-项目配置

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的已经被删除了
在这里插入图片描述

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()

通过数据库后台确认已经增加了三条数据
在这里插入图片描述
下面执行年龄大于等于30的删除

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

然后到数据库后台执行以下查询语句,发现此时刚刚增加的三条数据已经被删除
在这里插入图片描述

3、伪删除

  • 通常不会轻易在业务里把数据真的删除,取而代之的是做伪删除,即在表中增加一个布尔型字段(is_active),默认是True,执行删除时,将欲删除数据的is_active字段设置为False即可
  • 注意:使用伪删除时,确保显示数据的地方,均增加了is_active=True的过滤查询
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

redrose2100

您的鼓励是我最大的创作动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值