Предполагается, что "max_length" и "choices" в определении класса Model предотвращают вставку недопустимых значений в базу данных?

У меня есть ситуация, когда у меня есть модель типа:

class Box(models.Model):
    
  BOX_CHOICES = [('L','Large'),('M','Medium'),('S','Small')]
    
  size= models.CharField(max_length=1,choices=BOX_CHOICES, blank=True, null=True)

Я думал, что это гарантирует, что я не смогу добавить строку типа "Humongous" в поле размера. И все же, я смог сделать именно это, используя функцию get_or_create для вставки.
. Не могли бы вы объяснить, почему max_length и choices не ограничивают вставку?
. Спасибо!

get_or_create() (как и create()) не вызывает full_clean(), функцию валидации, которая проверяет такие вещи, как choices, max_length и т. д. Поэтому вам придется выполнить ее самостоятельно:

try:
    box = Box.objects.get(**your_get_values)
except Box.DoesNotExist:
    box = Box(**your_get_values, **any_other_values) 
    box.full_clean()
    box.save()

Валидаторы max_length и choices вызываются full_clean, как объясняется в документации. Вы можете вызвать этот метод вручную:

from django.core.exceptions import ValidationError
try:
    box = Box.objects.create(size="L")
    box.full_clean()
    box.save()
except ValidationError:
    pass
Вернуться на верх