Zwiększanie ślimaka przez uniknięcie błędu integralności w metodzie składowania modeli django

Mam model z dwoma polami jak poniżej

models.py

class Publisher(models.Model):
    name = models.CharField(max_length=200)
    slug = models.SlugField(max_length=150, unique=True)    

    def save(self, *args, **kwargs):
        if not self.id and not self.slug:
            slug = slugify(self.name)
            try:
                slug_exits = Publisher.objects.get(slug=slug)
                if slug_exits:
                    self.slug = slug + '_1'
            except Publisher.DoesNotExist:
                self.slug = slug
        super(Publisher, self).save(*args, **kwargs)

Tutaj tworzę ślimak na podstawiename jak widać powyżej

Więc kiedy próbujemy stworzyć wydawcę zname already exists, thesave metoda modelu doda_1 do końca.

A kiedy ponownie spróbujemy stworzyć nowy rekord z tym samymname, anIntegrity błąd zostanie podniesiony jak poniżej

>> Publisher.objects.create(name="abc")
   result: slug will be "abc"
>> Publisher.objects.create(name="abc")
   result: slug will be "abc_1"
>> Publisher.objects.create(name="abc")
   result: 

     .................
     .................
     34     del cursor
     35     del connection
---> 36     raise errorclass, errorvalue
     37 
     38 re_numeric_part = re.compile(r"^(\d+)")

IntegrityError: (1062, "Duplicate entry 'abc_1' for key 'slug'")

Więc czego chcę, to czy tytuł / slug już istnieje w bazie danych i czy slug zawiera w nim numer (na końcu jak abc_1), powinniśmy zwiększyć tę liczbę

Więc czego chcę to wszystkoincrement the number in the slug jak poniżej, jeśli tytuł / slug już istnieje w bazie danych

abc
abc_1
abc_2
abc_3  

Czy więc ktoś może mi dać znać, jak wdrożyć powyższą logikę zwiększania ślimaka?

Z góry dziękuję......

questionAnswers(1)

yourAnswerToTheQuestion