HSQLDB - Индексы
А database index- это структура данных, которая повышает скорость операций в таблице. Индексы могут быть созданы с использованием одного или нескольких столбцов, что обеспечивает основу как для быстрого случайного поиска, так и для эффективного упорядочивания доступа к записям.
При создании индекса следует учитывать, какие столбцы будут использоваться для выполнения SQL-запросов, и создать один или несколько индексов для этих столбцов.
На практике индексы также представляют собой тип таблиц, в которых хранится первичный ключ или поле индекса и указатель на каждую запись в реальной таблице.
Пользователи не могут видеть индексы. Они используются только для ускорения запросов и будут использоваться поисковой системой по базам данных для быстрого поиска записей.
Операторы INSERT и UPDATE занимают больше времени для таблиц, имеющих индексы, тогда как операторы SELECT выполняются быстрее для этих таблиц. Причина в том, что при вставке или обновлении базе данных также необходимо вставить или обновить значения индекса.
Простой и уникальный указатель
Вы можете создать уникальный индекс для таблицы. Аunique indexозначает, что две строки не могут иметь одинаковое значение индекса. Ниже приведен синтаксис для создания индекса таблицы.
CREATE UNIQUE INDEX index_name
ON table_name (column1, column2,...);
Вы можете использовать один или несколько столбцов для создания индекса. Например, создайте индекс для tutorials_tbl с помощью tutorial_author.
CREATE UNIQUE INDEX AUTHOR_INDEX
ON tutorials_tbl (tutorial_author)
Вы можете создать простой индекс для таблицы. Просто опустите ключевое слово UNIQUE из запроса, чтобы создать простой индекс. Аsimple index позволяет дублировать значения в таблице.
Если вы хотите проиндексировать значения в столбце в порядке убывания, вы можете добавить зарезервированное слово DESC после имени столбца.
CREATE UNIQUE INDEX AUTHOR_INDEX
ON tutorials_tbl (tutorial_author DESC)
Команда ALTER для добавления и удаления индекса
Есть четыре типа операторов для добавления индексов в таблицу:
ALTER TABLE tbl_name ADD PRIMARY KEY (column_list) - Этот оператор добавляет PRIMARY KEY, что означает, что индексированные значения должны быть уникальными и не могут быть NULL.
ALTER TABLE tbl_name ADD UNIQUE index_name (column_list) - Этот оператор создает индекс, значения которого должны быть уникальными (за исключением значений NULL, которые могут появляться несколько раз).
ALTER TABLE tbl_name ADD INDEX index_name (column_list) - Добавляет обычный индекс, в котором любое значение может встречаться более одного раза.
ALTER TABLE tbl_name ADD FULLTEXT index_name (column_list) - Это создает специальный индекс FULLTEXT, который используется для поиска текста.
Ниже приводится запрос на добавление индекса в существующую таблицу.
ALTER TABLE testalter_tbl ADD INDEX (c);
Вы можете отбросить любой ИНДЕКС, используя предложение DROP вместе с командой ALTER. Ниже приводится запрос на удаление созданного выше индекса.
ALTER TABLE testalter_tbl DROP INDEX (c);
Отображение информации INDEX
Вы можете использовать команду SHOW INDEX, чтобы вывести список всех индексов, связанных с таблицей. Вывод в вертикальном формате (определяемый \ G) часто бывает полезным с этим оператором, чтобы избежать переноса длинной строки.
Ниже приведен общий синтаксис для отображения информации индекса для таблицы.
SHOW INDEX FROM table_name\G