215 похожих чатов

Приветствую! Прошу прощения за небольшой оффтоп - нужна помощь по

БД/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 уникальное?

3 ответов

7 просмотров

slug это уникальное значение, та и индекс, скорее все, стоит Чекни сорцы, там все должно быть

Более развернутый ответ: Ты, скорее всего, используешь вот эту либу https://django-autoslug.readthedocs.io Вот исходники твоего поля https://github.com/justinmayer/django-autoslug/blob/master/autoslug/fields.py Скрин этого файла выше говорит о том, что по дефолту индекс все таки устанавливается, что ускоряет поиск и объясняет разницу в скорости Чтобы сравнять эту скорость, попробуй также установить индекс на поле name

Похожие вопросы

Обсуждают сегодня

читать файл максимально быстро? странный вопрос))
zamtmn
52
всем привет! углубившись в плюсы и начав изучать реверсинг понял, что без асм'а никуда со своими высокоабстрактными представлениями начал изучать механизмы асма, и не совсем п...
9
буквально один оставшийся вопрос при выполнении строчки mov eax, 5 операнд "5" будет присутствовать где-либо в памяти (любой), кроме как в памяти блока .code? подвопрос: как...
12
Всем ку. Подскажите, если задекларировал массив так: int arr[10] = {1, 2, 3, 4}, то в arr[4] будет мусор или нуль?
Sasha K
14
я не понимаю mov [r11+8],rcx и прочие. мы записываем значение из rcx, куда?
Bor
15
у меня такой вопрос про память в x86 возник, может кто пояснить?.. у процессора есть (как минимум) 3 типа адресов (названия "п1", "п2", "п3" --- мои, чтобы проще было дальше)...
Toideng
5
а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
А какие расширения активно используются в промышленности? Именно идейные, по типу гадт, а не всякие оверлоадедстрингс
Степан
11
у процессора есть (как минимум) 3 типа адресов (названия "п1", "п2", "п3" --- мои, чтобы проще было дальше): - "п1" --- виртуальный адрес, то есть тот, который ресолвится в "п...
Toideng
3
Guys Who’s kurdish on this group?
Hiwa Amiri
11
Карта сайта