Я хочу, чтобы моя форма проверяла, существует ли уже такое же имя и дата в postgresql, поэтому она не создает дубликат.
models.py:
class Event(models.Model):
week = models.DateField(blank=False)
name = models.ForeignKey(Employee, default=None, on_delete=models.CASCADE)
sunday = models.CharField(max_length=50, default=None, null=True)
monday = models.CharField(max_length=50)
tuesday = models.CharField(max_length=50)
wednesday = models.CharField(max_length=50)
thursday = models.CharField(max_length=50)
friday = models.CharField(max_length=50)
saturday = models.CharField(max_length=50, default=None, null=True)
def __str__(self):
return self.week
views.py:
def test2(request):
locationList = Location.objects.all().order_by('name') #Pulls location data from location table
clientList = Client.objects.all().order_by('name') #Pull client data from client table
if request.method == 'POST':
form1 = EventForm2(request.POST) #Displays form to be filled out by user
if form1.is_valid():
event = form1.save() #Saves form if valid data is entered
messages.info(request, 'Successfully added')
return HttpResponseRedirect(reverse('test2')) #Refreshes page to default
else:
form1 = EventForm2() #Form remains the same until valid data has been entered
eventList = Event.objects.all().order_by('week', 'name')
return render(request, 'app/test2.html', { # brings all the data into selected html
"form": form1,
"locationList": locationList,
"clientList": clientList,
"eventList": eventList,
})
Так, если, например, 27-01-2019;Боб Дилан уже существует в БД, форма не будет действительной для отправки