我想删除一个特定的记录,比如:

delete from table_name where id = 1;

如何在django模型中做到这一点?


当前回答

您可以直接从管理面板中删除对象,或者也可以通过输入python3 manage.py shell (Linux中的python3)从交互式shell中删除特定或选定的id。 如果你想让用户通过浏览器(提供可视化界面)删除对象,例如,从数据库中删除ID为6的员工,我们可以用以下代码实现这一点: Emp = employee.objects.get(id=6).delete()

这将删除ID为6的员工。

如果你想删除数据库中存在的所有雇员,而不是get(),指定all()如下所示: employee.objects.all () delete ()

其他回答

您也可以使用get_object_or_404(),而不是直接使用get(),因为在使用get()时,我们显式地引发404错误。

但是,在使用get_object_or_404时,它是自动完成的。

根据4.0文档,在给定的模型管理器上调用get(),但它会引发Http404而不是模型的DoesNotExist异常。

像这样使用它:

批量删除:

AnyModel.objects.filter(id=id).delete()

如果要删除单个实例,请使用get_object_or_404()代替get(),如下所示:

instance=get_object_or_404(anyModel,id=id)
instance.delete()

如果,未找到则自动引发404。

如果使用get(),而数据不存在,则会导致错误。在这种情况下,可以使用get_object_or_404自动处理错误。然而,get_object_or_404的问题在于,它在获得所需对象之前过滤所有数据,这对于大型数据集来说效率很低。为了避免这种情况,你可以使用一个自定义方法,比如下面的例子:

class CustomException(APIException):
    status_code = 400
    default_detail = 'Custom exception occurred'

def get_object_or_raise(model, **kwargs):
    try:
        return model.objects.get(**kwargs)
    except model.DoesNotExist:
        raise CustomException({'error': f"{model.__name__} with {kwargs} does not exist"})

当你想要得到的时候你可以做到

instance = get_object_or_raise(anyModel, id=id)
instance.delete()

如果您想删除一个实例,那么请编写代码

entry= Account.objects.get(id= 5)
entry.delete()

如果你想删除所有实例,然后写代码

entries= Account.objects.all()
entries.delete()

有几种方法:

直接删除:

SomeModel.objects.filter(id=id).delete()

从实例中删除:

instance = SomeModel.objects.get(id=id)
instance.delete()
MyModel.objects.get(pk=1).delete()

如果具有指定主键的对象不存在,这将引发异常,因为它首先尝试检索指定的对象。

MyModel.objects.filter(pk=1).delete()

如果具有指定主键的对象不存在,它不会引发异常,而是直接产生查询

DELETE FROM my_models where id=1