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

Добрый вечер. Если у меня в запросе в условии WHERE

всегда используется две колонки, следует создать один индекс по двум полям? Будет ли выборка идти быстрее, чем если бы было создано 2 индекса на каждое поле?
База postgres

12 ответов

9 просмотров

Шли запрос, посмотрим

NoName- Автор вопроса
Ilya Zviagin
Шли запрос, посмотрим

SELECT * FROM table WHERE entity_type = 0 AND entity_id = 3456 Что то типо такого. А будет разница если выборка не по 2 полям а по 4? Все поля кроме entity_id smallint, а сам entity_id int

NoName
SELECT * FROM table WHERE entity_type = 0 AND enti...

А определение таблицы пришли...

NoName
SELECT * FROM table WHERE entity_type = 0 AND enti...

Нет, разница будет для каждого запроса

NoName- Автор вопроса
Ilya Zviagin
А определение таблицы пришли...

Добрый день. Вот более подробно, с таблицами и запросами. Есть две таблицы: 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 полям?

ап

NoName
Добрый день. Вот более подробно, с таблицами и зап...

Вопрос в том как правильно организовать индексы в первой таблице? Сделать два разных индекса по полям type и periodicity, либо один индекс по двум полям? Один по двум полям, конечно. (type, periodicity) или наоборот порядок. Но чтобы знать, нужен ли индекс, надо знать, сколько записей в таблице всего и сколько приходится на каждую уникальную пару (type, periodicity) И нужны ли еще индексы на каждую колонку в таблице table_two, если там уже есть уникальный индекс по 4 полям? Где индекс по четырём полям ? Нет никакого индекса.

NoName- Автор вопроса
Ilya Zviagin
Вопрос в том как правильно организовать индексы в ...

Но чтобы знать, нужен ли индекс, надо знать, сколько записей в таблице всего и сколько приходится на каждую уникальную пару (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);

NoName
Но чтобы знать, нужен ли индекс, надо знать, сколь...

А сколько вообще записей в этих таблицах?

NoName
Но чтобы знать, нужен ли индекс, надо знать, сколь...

Этот индекс CREATE UNIQUE INDEX table_two_unique_idx ON table_two(winner_target_type, winner_target_id, nomination_type, nomination_periodicity); прямо подходит под запрос (если конечно индекс там вообще нужен) И нужны ли еще индексы на каждую колонку в таблице table_two, если там уже есть уникальный индекс по 4 полям? Нет, для этого запроса индексы более не нужны никакие.

NoName- Автор вопроса
Ilya Zviagin
Этот индекс CREATE UNIQUE INDEX table_two_uniqu...

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

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

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

Ребят, а за скок можно впарить анон чат с апишкой и веб админкой ?
Eugene Неелов
15
А как лучше конвертировать физический адрес в виртуальный при маппинге? В случае ядра у меня, например, direct mapping, первые 768МБ я как есть мапплю в higher half, а остальн...
Evg Resh
26
с помощью чего можно бота добавить как админа в чат? (условно в боте есть кнопка, нажатие на которую приводит тебя к выбору чата и выдаче прав боту)
ηє νєямσяє
5
а чем лучше всего сделать глобальный лок, если много нодов, до сотни? ну то есть мне надо, чтобы некоторые операции с объектом не происходили одновременно. перемещение между н...
Д. П.
15
'frakturBold' => ['𝖆', '𝖇', '𝖈', '𝖉', '𝖊', '𝖋', '𝖌', '𝖍', '𝖎', '𝖏', '𝖐', '𝖑', '𝖒', '𝖓', '𝖔', '𝖕', '𝖖', '𝖗', '𝖘', '𝖙', '𝖚', '𝖛', '𝖜', '𝖝', '𝖞', '𝖟', '𝕬', '𝕭', '𝕮', '𝕯'...
Roma
4
Ты просто гитлеровскую эстетику плохо понимаешь. Он же всё под Цезаря делал. А это как бы запрещённый приём в политике. Пиджаки они зачем все носят? Чтобы показать что они тип...
Ivan Kropotkin
4
Добрый день, не подскажите, если в OC-V3 поменять страндартную директорию /storage/ на /storage2/ - не будет сильно много проблем ?
Max Dubovsky
32
Всем привет, есть таблица компонентов (например материнка, процессор, видеокарта и тд) components и нужно еще реализовать механизм "совместимости" (те какой-то словарь, мол од...
Vladimir
2
Подскажите как мне лучше держать websocket сединение и переодически передавать в него данные? Сначала я сделал так: for _ in 1...1000 { try? await ws.send("test") try...
Mihail Verenich
2
Добрый день, подскажите как правильно сделать filter в backend-e. Есть модель (товар) у который связь belongsToMany (компания), компаний > 4k, поэтому выборку типа ->all(); н...
Max Dubovsky
7
Карта сайта