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

Доброго дня и крепкого вам здоровья. Может быть натолкнёте меня

на какие-то мысли. Есть таблицы А и Б, таблицы соединяются по первичному ключу из таблицы А, в фильтре участвуют обе таблицы и тут начинается проблема – сортировка по полю из таблицы A. Запрос выглядит примерно вот так:

select A.Id from Б
join A on А.Id = Б.А_Id
where Б.Поле_Фильтр = @значение_для_фильтра
order by A.Поле_для_сортировки_типа_дата desc

Вот такой, казалось бы, совсем простой запрос. Но он таит в себе жутко неприятную вещь – в плане данное соединение ввиду количества данных в таблицах представляется как Nested Loops. Теперь осталось только правильно выбрать, по какой таблице начинать идти, а какую внутри проверять и вот она проблема. Большинство выборок where Б.Поле_Фильтр = @значение_для_фильтра имеют минимальное количество результатов на выходе (зачастую меньше даже 100, используя статистику сиквела всё логично) и сиквел успешно кэширует план, где цикл идёт по данным из таблицы Б и внутри по А, ну а после сортировку делает. Но вот есть такие моменты, когда where Б.Поле_Фильтр = @значение_для_фильтра вернет значительно большое количество элементов и если бы он шёл по таблице А, то эффективность просто значительно, очень значительно выше, учитывая то, что на ней есть индекс, где поле для сортировки уже отсортировано и повторной сортировки не нужно. Сейчас самое простое решение option (recompile), сиквел под новый параметр @значение_для_фильтра перестраивает план и всё хорошо, но сам вызов recompile несёт издержки. Есть идеи?

1 ответов

12 просмотров

"несёт издержки" - огромные и невыносимые? работает же, что еще надо? )

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

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

Anyone here suffers from unexplained aural migraines, who would be up for talking for a bit? Doesn't *have* to be aural, but I am not asking about headaches, I mean actual mi...
Martin Rys
55
подскажите пожалуйста, как мне освободить результат записанный в переменную result? в чем проблема подскажите если МОЖЕТЕ?
Михаил Helper
28
есть тут кто-то , кто только начал изучать си? если проходите курс на степике или как-то сами изучаете, пишите, может, скооперируемся?..
Eule
25
Слушайте, ещё такая интересная задачка. Сделан аудит действий пользователей через триггеры в базе, соответственно каждый пользователь имеет свой логин и пароль в базе. Это пре...
Сергей Бычков
12
Скажите, тут нет проблемы? IMyInterface1 = interface function GetInterface2: IInterface2; ... function TMyInterface.GetInterface2: IInterface2; begin Result := TI...
Ruslan aka DUDE
18
вопрос по москвину - не понимаю вот такого вопроса похоже Сколько разных всегда завершающихся функций с типом a -> a -> b -> a -> a можно реализовать? Две функции одинаково...
Fedor
11
Кстати, раз про скачивание файлов разговор зашел) Сделал бота для себя (транскрибирующего и суммаризирующего встречи) но не ожидал что за 2 месяца 10к пользователей набежит😅...
Andrey Obolenskiy
8
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
Утра доброго. Просветите пожалуйста. Хочу сделать rest сервер на делфи. Посмотрел 3 фреймворка: dmvc, Mars, mormot. Ни в одном из них не упоминается ассинхронная обработка вхо...
Сергей Бычков
10
возможно для форматирования TimeStampZ нужен другой механизм, не?
Роман Лях (rgreat)
13
Карта сайта