get_or_create抛出完整性错误

时间:2013-10-14 14:04:03

标签: python django django-forms

鉴于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'")

任何人都知道发生了什么事?

3 个答案:

答案 0 :(得分:26)

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

试试这个:

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 heredefaults=参数就是您所需要的。

答案 1 :(得分:0)

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

  • 电子邮件
  • 用户名
  • 如first_name
  • 姓氏

因此,所有四个字段合并都没有记录。

你应该这样做:

myuser, created = User.objects.get_or_create(
   username=myemail, defaults={'first_name': first_name, 'last_name': last_name, 'email': myemail})

答案 2 :(得分:0)

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