БД/Django
Имеется вот такая вот простая Django модель:
class Publisher(TimeStampedModel):
name = models.CharField(max_length=255)
slug = AutoSlugField(unique=True, always_update=True, populate_from='name')
В БД есть запись, для которой name==slug. При этом SELECT запрос через указание WHERE name = "X" выполняется за 0.256 секунды, а если делать WHERE slug = "X", то время выполнения 0.09 секунды, то есть разница в скорости выполнения SQL запроса ~3x. Вопрос: почему так? Нигде не нашёл в документации AutoSlugField что она как-то повышает скорость поиска в БД. Или это связано с тем, что поле slug уникальное?
slug это уникальное значение, та и индекс, скорее все, стоит Чекни сорцы, там все должно быть
Более развернутый ответ: Ты, скорее всего, используешь вот эту либу https://django-autoslug.readthedocs.io Вот исходники твоего поля https://github.com/justinmayer/django-autoslug/blob/master/autoslug/fields.py Скрин этого файла выше говорит о том, что по дефолту индекс все таки устанавливается, что ускоряет поиск и объясняет разницу в скорости Чтобы сравнять эту скорость, попробуй также установить индекс на поле name
Обсуждают сегодня