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ę......