这是我的 forms.py 片段
class ContactForm(forms.ModelForm):
class Meta:
model = Contact
exclude = ('user',)
这是我的views.py 片段
def contact(request, template_name):
if request.method == "POST":
form = ContactForm(request.POST)
if form.is_valid():
obj = form.save(commit=False)
obj.user = request.user
obj.save()
return HttpResponseRedirect('/newuser/step2/')
else:
if (Contact.objects.filter(user=request.user)):
contact_obj = Contact.objects.get(user_id=request.user.id)
form = ContactForm(instance = contact_obj)
else:
form = ContactForm()
return render_to_response(template_name, RequestContext(request, {'form' : form}))
当我第一次为注册用户填写数据时,数据成功进入表格。当我再次访问表单时,加载了数据库中的数据,但是当我重新提交时,出现以下错误
Exception Type: IntegrityError
Exception Value: (1062, "Duplicate entry '3' for key 'user_id'")
Exception Location: /usr/lib/python2.7/dist-packages/MySQLdb/connections.py in defaulterrorhandler, line 36
我的联系人表有自动生成的“id”字段作为主键,而“user_id”是外键字段。“3”是登录用户的“user_id”。
我正在尝试做一件非常简单的事情,将用户的一些数据存储在一个表中并将其链接起来。有更好的方法吗?我在这里做错了什么?