Джанго условно уникален - PullRequest
6 голосов
/ 23 ноября 2011

У меня есть модель, которая выглядит следующим образом:

class LibraryEntry(models.Model):
  host_lib_song_id = models.IntegerField()
  song = models.CharField(max_length=200)
  artist = models.CharField(max_length=200)
  album = models.CharField(max_length=200)
  owning_user = models.ForeignKey(User)
  is_deleted = models.BooleanField(default=False)

Теперь, если я выбираю где is_deleted=False, комбинация host_lib_song_id и owning_user должна быть уникальной.Как я могу это выразить?

Ответы [ 2 ]

11 голосов
/ 23 ноября 2011

Переопределение validate_unique для проверки уникальности, если is_deleted равно False, более уместно:

...

def validate_unique(self, exclude=None):
    if not self.is_deleted and \
       LibraryEntry.objects.exclude(pk=self.pk).filter(host_lib_song_id=self.host_lib_song_id, owning_user=self.owning_user).exists():
        raise ValidationError('Some error message about uniqueness required')
    super(LibraryEntry, self).validate_unique(exclude=exclude)
4 голосов
/ 23 ноября 2011

Вы не можете выразить это с помощью ограничения Meta.unique_together, но с помощью проверки модели django :

class LibraryEntry(models.Model):
    def clean(self):
        from django.core.exceptions import ValidationError
        try:
            # try to find a duplicate entry and exclude 'self'
            duplicate = LibraryEntry.objects.exclude(pk=self.pk)\
                .get(owning_user=self.owning_user, 
                     host_lib_song_id=self.host_lib_song_id,
                     is_deleted=False)
            raise ValidationError('Library Entry already exists!')
        except: LibraryEntry.DoesNotExist:
            # no duplicate found
            pass
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...