鉴于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'")
任何人都知道发生了什么事?
答案 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
here。 defaults=
参数就是您所需要的。
答案 1 :(得分:0)
您要求django根据以下四个条件获取记录:
因此,所有四个字段合并都没有记录。
你应该这样做:
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