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