27

鉴于 object.get_or_create() 的全部意义在于获取对象(如果它已经存在),我不明白为什么它会为此代码引发完整性错误:

class UserAdd(TemplateView):

def post(self, request, *args, **kwargs):
    context = self.get_context_data(*args, **kwargs)
    form = UserAddForm(request.POST)
    if form.is_valid():
        first_name = form.cleaned_data['first_name']
        last_name = form.cleaned_data['last_name']
        myemail = form.cleaned_data['email']
        mypass = form.cleaned_data['password']
        if myemail and mypass:
            myuser,created = User.objects.get_or_create(email=myemail, username=myemail, first_name=first_name, last_name=last_name)
            if created:
                myuser.set_password(mypass)
    return HttpResponseRedirect('/')

这是错误:

django.db.utils.IntegrityError IntegrityError: (1062, "Duplicate entry 'user@domain.com' for key 'username_UNIQUE'")

有谁知道发生了什么?

4

3 回答 3

34

发送到get_or_create方法中的参数需要完全匹配,否则 django 的 ORM 会尝试创建一个新对象,并且由于会违反主键/唯一列约束,因此您会收到错误消息。

尝试这个:

if form.is_valid():
    first_name = form.cleaned_data['first_name']
    last_name = form.cleaned_data['last_name']
    myemail = form.cleaned_data['email']
    mypass = form.cleaned_data['password']
    if myemail and mypass:
        myuser,created = User.objects.get_or_create(email=myemail, defaults = {'username': myemail, 'first_name': first_name, 'last_name': last_name})
        if created:
            myuser.set_password(mypass)

return HttpResponseRedirect('/')

get_or_create在此处阅读更多信息。defaults=论据是你所需要的。

于 2013-10-14T14:08:50.890 回答
0

您要求 django 根据四个条件获取记录:

  • 电子邮件
  • 用户名

所以所有四个字段组合起来没有记录。

你应该做:

myuser, created = User.objects.get_or_create(
   username=myemail, defaults={'first_name': first_name, 'last_name': last_name, 'email': myemail})
于 2013-10-14T14:08:46.823 回答
0

save()重新定义模型的方法后,我遇到了类似的错误。事实证明,如果您save在模型中多次调用,则所有后续调用都应使用force_insert=True关键字参数进行。就我而言,我不得不更改self.save(*args, **kwargs)self.save()on second call 以消除错误。有关更多详细信息,请阅读此处:https ://code.djangoproject.com/ticket/28253

于 2019-03-22T21:34:32.393 回答