всегда используется две колонки, следует создать один индекс по двум полям? Будет ли выборка идти быстрее, чем если бы было создано 2 индекса на каждое поле?
База postgres
Шли запрос, посмотрим
SELECT * FROM table WHERE entity_type = 0 AND entity_id = 3456 Что то типо такого. А будет разница если выборка не по 2 полям а по 4? Все поля кроме entity_id smallint, а сам entity_id int
А определение таблицы пришли...
Нет, разница будет для каждого запроса
Добрый день. Вот более подробно, с таблицами и запросами. Есть две таблицы: CREATE TABLE table_one ( id SERIAL NOT NULL PRIMARY KEY, type INT NOT NULL, periodicity INT NOT NULL, date_from TIMESTAMP NOT NULL, date_to TIMESTAMP NOT NULL, date TIMESTAMP NOT NULL DEFAULT NOW() ); CREATE TABLE table_two ( id SERIAL NOT NULL PRIMARY KEY, winner_target_type INT NOT NULL, winner_target_id INT NOT NULL, nomination_type INT NOT NULL, nomination_periodicity INT NOT NULL, position INT NOT NULL, count INT NOT NULL ); В таблице table_two по полям (winner_target_type, winner_target_id, nomination_type, nomination_periodicity) построен один уникальный индекс. Из таблицы table_one записи будут выбираться вот так SELECT * FROM table_one WHERE type = 0 AND periodicity = 4 ORDER BY id DESC LIMIT 1; Из таблицы table_two выборка осуществляется так SELECT * FROM table_two WHERE winner_target_type = 0 AND winner_target_id = 35698 AND nomination_type = 0 AND nomination_periodicity = 4; Вопрос в том как правильно организовать индексы в первой таблице? Сделать два разных индекса по полям type и periodicity, либо один индекс по двум полям? И нужны ли еще индексы на каждую колонку в таблице table_two, если там уже есть уникальный индекс по 4 полям?
ап
Вопрос в том как правильно организовать индексы в первой таблице? Сделать два разных индекса по полям type и periodicity, либо один индекс по двум полям? Один по двум полям, конечно. (type, periodicity) или наоборот порядок. Но чтобы знать, нужен ли индекс, надо знать, сколько записей в таблице всего и сколько приходится на каждую уникальную пару (type, periodicity) И нужны ли еще индексы на каждую колонку в таблице table_two, если там уже есть уникальный индекс по 4 полям? Где индекс по четырём полям ? Нет никакого индекса.
Но чтобы знать, нужен ли индекс, надо знать, сколько записей в таблице всего и сколько приходится на каждую уникальную пару (type, periodicity) Значения в таблицу будут добавляться с определенной периодичностью. Есть периодичность равная одному часу. Эта информация и хранится в колонке periodicity. И есть 6 типов(колонка type). Соответственно каждый день в таблицу будут добавляться 144 новые записи. Соответственно за день будет добавлено 24 записи с одинаковыми парами type, periodicity. Где индекс по четырём полям ? Нет никакого индекса. Индекс вот так создается CREATE UNIQUE INDEX table_two_unique_idx ON table_two(winner_target_type, winner_target_id, nomination_type, nomination_periodicity);
А сколько вообще записей в этих таблицах?
Этот индекс CREATE UNIQUE INDEX table_two_unique_idx ON table_two(winner_target_type, winner_target_id, nomination_type, nomination_periodicity); прямо подходит под запрос (если конечно индекс там вообще нужен) И нужны ли еще индексы на каждую колонку в таблице table_two, если там уже есть уникальный индекс по 4 полям? Нет, для этого запроса индексы более не нужны никакие.
подходит под запрос (если конечно индекс там вообще нужен) да, уникальный нужен на комбинацию этих полей
Обсуждают сегодня