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

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

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

12 ответов

17 просмотров

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

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

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

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

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

Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
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
Вот еще странный косяк, подскажите как бороться. Я git clone сделал себе всего embassy и примеры там запускаю. Всё хорошо. Но вот решил в cargo.toml зависимости не как в приме...
Lukutin R2AJP
3
Всем привет, нужна как никогда, нужна помощь с IO в загрузчике. Пишу в code16 после установки сегментных регистров, пишу вывод символа. Пробовал 2 варианта: # 1 mov $0x0E, %a...
Shadow Akira
14
Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
Раз начали говорить про embassy, то присоединюсь со своими парой вопросов. 1) Есть ли сопоставимые аналоги для асинхронного кода в emdebbed? 2) Можно ли внутри задач embassy ...
NI_isx
6
Объясните, пожалуйста, почему компилятор ругается на использование в условии неинициализированной переменной: int x; Task.Run(async () => { x = await somefunc(); }).Wait...
Александр
5
Всем привет. Ребята, подскажите, пожалуйста. у ботов есть ограничение на отправку сообщений - 30 сообщений в секунду, эти ограничения накладываются на все сообщения? или на со...
Artem Stormageddon
4
1. https://www.kaggle.com/code/ahmadrezagholami2001/housing-estimation-linear-regression 2. https://www.kaggle.com/code/ahmadrezagholami2001/uncovering-quality-in-wines-logis...
Ahmadreza
1
Коллеги, я тут для личных нужд пошел ставить MQTT сервер, пощупал mosquitto, но ужаснулся отсутствию такой банальности, как HTTP API для посмотреть список топиков. А тут что,...
Maksim Lapshin
14
Карта сайта