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

Всем привет, у меня есть табличка order { id shop_id date type ... } Исторически получилось, что связь

этой таблицы с другой сущностью происходит по полям (shop_id, date,type)

То есть делаются запросы из разряда
where (shop_id = .. and date = ... and type = ...) or (shop_id = .. and date = ... and type = ...)
И этот кондинш может быть длинный

Сейчас нет составного индекса на` (shop_id, date, type) `- это первое, что хочу пришло на ум, чтобы оптимизировать запрос
Но вот меня смущает этот длинный where, подскажите, какие есть методы оптимизаций данного запроса?

5 ответов

16 просмотров

where (shop_id, date, type) in ((... , ... , ...), (... , ... , ...), (... , ... , ...)) укоротить можно так, но смысла особого от этого нет 😂

Dmitry-Chexkh Автор вопроса
Григорий Яхонтов
where (shop_id, date, type) in ((... , ... , ...),...

Меня смущает, что этот запрос по индексам не очень будет отрабатывать Вообще такой составной индекс реально ускорит работу?

Dmitry Chexkh
Меня смущает, что этот запрос по индексам не очень...

если по нему отработает, то ускорит выборку. Но может замедлить обновление.

А вы уверены, что вам надо что-то оптимизировать? Анализ планов произведён?

Dmitry-Chexkh Автор вопроса
Roman Sergeev
А вы уверены, что вам надо что-то оптимизировать? ...

Вообще експлейн аналайз выдал оч хороший результат, и кажется оптимизация здесь излишняя

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

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

30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
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
Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
Карта сайта