我正在使用django 1.0,我使用Django书中的示例创建了我的模型。我能够执行添加数据的基本功能;现在我需要一种方法来检索数据,将其加载到表单(change_form ?!或其他),编辑并将其保存回数据库。其次,我如何删除数据库中的数据?即搜索,选择然后删除!
请向我展示我需要在view.py
和urls.py
上编写的代码示例,以执行此任务。
答案 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。然后用具体细节修改你的问题。