失败UNIQUE约束:music_playlist.owner_id
问题描述:
用户可以注册并登陆我的网站。那些当前登录到我的网站的用户可以创建自己的播放列表。但是,创建按钮提交时,它返回我这个错误:失败UNIQUE约束:music_playlist.owner_id
UNIQUE constraint failed: music_playlist.owner_id
这里是我的models.py:
class Playlist(models.Model):
name = models.CharField(max_length=200, null=False, blank=False,default='')
owner = models.ForeignKey(User, unique=True,null=True)
def __str__(self):
return self.name
@property
def playlist_id(self):
return self.id
这是我的views.py(发生错误):
@login_required
def create_playlist(request):
form = PlaylistForm(request.POST or None)
if form.is_valid():
data = form.cleaned_data
playlist = form.save(commit=False)
playlist.owner = request.user
playlist.save()
#playlist_name = form.cleaned_data['name']
context={
'playlist':playlist,
'form':form,
}
return render(request, 'create_playlist.html', context)
context = {
"form": form,
}
return render(request, 'create_playlist.html', {'form': form,})
当用户进入create_playlist.html,他们可以键入播放列表的名称,然后点击创建按钮。我希望播放列表的所有者字段与当前登录的用户相同。
你的帮助是非常赞赏。
答
请更正你的代码
class Playlist(models.Model):
name = models.CharField(max_length=200, null=False, blank=False,default='')
owner = models.ForeignKey(User, null=True)
def __str__(self):
return self.name
@property
def playlist_id(self):
return self.id
当你让外国密钥所有者独一无二的,这意味着一个用户只能有一个播放列表。当您尝试添加其他播放列表相同的用户你得到这个错误
UNIQUE constraint failed: music_playlist.owner_id
如果你想一个用户只有一个播放列表,使用OneToOneField