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

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

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

12 ответов

20 просмотров

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

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...

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

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

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

Гайс, вопрос для разносторонее развитых: читаю стрим с юарта, нада выделять с него фреймы с определенной структурой, если ли чо готовое, или долбаться с ринг буффером? нада у...
Vitaly
9
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
длина пакета фиксированная, или меняется?
Okhsunrog
7
Вот еще странный косяк, подскажите как бороться. Я git clone сделал себе всего embassy и примеры там запускаю. Всё хорошо. Но вот решил в cargo.toml зависимости не как в приме...
Lukutin R2AJP
5
А в каком формате фреймы? Сам формат сейчас придумываешь, или что-то готовое нужно распарсить?
Okhsunrog
5
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
Всем привет, нужна как никогда, нужна помощь с IO в загрузчике. Пишу в code16 после установки сегментных регистров, пишу вывод символа. Пробовал 2 варианта: # 1 mov $0x0E, %a...
Shadow Akira
14
Раз начали говорить про embassy, то присоединюсь со своими парой вопросов. 1) Есть ли сопоставимые аналоги для асинхронного кода в emdebbed? 2) Можно ли внутри задач embassy ...
NI_isx
6
сделал сайт, прикрутил в боте сайт, и виджет логина. как автоматически логинить пользователя в аккаунт(телеграм), при входе с бота?
Александра Чернивецкая
5
Карта сайта