如何在Django中编辑和删除数据?

时间:2008-11-22 10:28:57

标签: python django editing

我正在使用django 1.0,我使用Django书中的示例创建了我的模型。我能够执行添加数据的基本功能;现在我需要一种方法来检索数据,将其加载到表单(change_form ?!或其他),编辑并将其保存回数据库。其次,我如何删除数据库中的数据?即搜索,选择然后删除!

请向我展示我需要在view.pyurls.py上编写的代码示例,以执行此任务。

3 个答案:

答案 0 :(得分:24)

假设你有一个模型员工。要使用主键emp_id编辑条目,请执行以下操作:

emp = Employee.objects.get(pk = emp_id)
emp.name = 'Somename'
emp.save()

删除它只是:

emp.delete()

所以完整视图将是:

def update(request, id):
   emp = Employee.objects.get(pk = id)
   #you can do this for as many fields as you like
   #here I asume you had a form with input like <input type="text" name="name"/>
   #so it's basically like that for all form fields
   emp.name = request.POST.get('name')
   emp.save()
   return HttpResponse('updated')

def delete(request, id):
   emp = Employee.objects.get(pk = id)
   emp.delete()
   return HttpResponse('deleted')

在urls.py中你需要两个这样的条目:

(r'^delete/(\d+)/$','myproject.myapp.views.delete'),
(r'^update/(\d+)/$','myproject.myapp.views.update'),

我建议你看看docs

答案 1 :(得分:0)

要执行上述任一操作,您需要使用称为查询的内容。

请点击下面的链接以获取有关此文档的出色文档! (https://docs.djangoproject.com/en/2.2/topics/db/queries/

要删除数据:

b = ModelName.objects.get(id = 1)
b.delete()

这将删除ID为1的模型对象

要编辑数据:

b = ModelName.objects.get(id = 1)
b.name = 'Henry'
b.save()

这会将ID为1的模型对象的名称更改为Henry。

答案 2 :(得分:-4)

阅读以下内容:The Django admin site。然后用具体细节修改你的问题。