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的过滤查询