Действительно индексирует на Varchar, делают различие в производительности?

Действительно индексирует на varchar столбце, делают запрос выполненным медленнее? Я могу заставить это быть интервалом, и я не должен делать ПОДОБНОГО сравнения %.

38
задан Ron Klein 3 March 2011 в 10:07
поделиться

4 ответа

Does index on a varchar column make the query run slower?

No, it does not.
If the optimizer decides to use of the index, the query will run faster. INSERTs/UPDATEs/DELETEs on that table will be slower, but not likely enough to notice.

I don't need to do the LIKE % comparison

Be aware that using:

LIKE '%whatever%'

...will not use an index, but the following will:

LIKE 'whatever%'

The key is wildcarding the lefthand side of the string means that an index on the column can't be used.

Also know that MySQL limits the amount of space set aside for indexes - they can be up to 1000 bytes long for MyISAM (767 bytes for InnoDB) tables.

83
ответ дан 27 November 2019 в 03:12
поделиться

Если вы можете заменить свой столбец varchar на целое число (что, я думаю, именно то, на что вы намекаете), то индекс, включающий целочисленный столбец, будет работать лучше, чем столбец varchar по нескольким причинам.

  1. Размер индекса будет меньше и потребуется меньше страниц.
  2. Сравнение целых чисел намного лучше, чем varchar.
11
ответ дан 27 November 2019 в 03:12
поделиться

Indexing don't make query slower, database size just get bigger, So go ahead and give it a try.

You should able to get better performance on fetching rows but its depends on your data, your queries.

7
ответ дан 27 November 2019 в 03:12
поделиться

You are not going to be making your queries any slower by indexing. If you can make the column a type int, I would recommend doing so as most RDBMS's can search int's faster than varchars

2
ответ дан 27 November 2019 в 03:12
поделиться
Другие вопросы по тегам:

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