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

Возможно глупенький вопрос, но как подходить к оптимизации запросов? Допустим, есть

запрос и есть его план исполнения(сейчас как раз учусь читать и понимать его). По-тихоньку формируется понимание, что нам говорит план исполнения запроса, а вот понимание, что можно сделать, чтобы улучшить запрос - нет
То есть, есть ли обобщенный подход к оптимизации?
Как понять, что запрос не оптимальный и его можно улучшить(не просто интуитивное понимание, а-ля, ну тут вроде запрос простой, а работает медленно, наверное чет не то. а как то более научно)
В какую сторону смотреть? (ибо когда сталкиваешься с этим как новичок, то несколько теряешься)

4 ответов

5 просмотров

1.Ищи в плане самые дорогие узлы по костам или по времени. 2. Ищи sequence scan - иногда надо просто добавить индекс (не всегда) 3. Смотри значение rows для плана и при фактическом исполнении - большая разница говорит об устаревшей статистике

Определить какие данные вам нужны. Затем понять как их можно выбрать, какими алгоритмами и какими обращениями к памяти их можно выбрать. Посчитать сколько это будет занимать времени — вот придумал метод доступа, его и посчитать. Затем сравнить время с тем что получилось и сравнить метод доступа с тем что сервер предложыл. Если примерно совпадает время и другие затратя ресурсов или не очень плохо всё значит куда деваться лучше лучше не придумывается.

4. при использовании analyze, buffers смотреть значения read -чтения с диска и buffers- чтение из оперативной памяти. Посмотреть в мониторинге значение cache hit rate - хорошие значения 90% и выше. 5. Если есть temp written возможно стоит посмотреть в сторону увеличения work_mem - либо уменьшить объем сортировок в запросе.

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

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

@MrMiscipitlick А можешь макрос написать, который будет вычислять смещение относительно переданных меток? Просто .label1-.label2, и вернуть значение.
КТ315
35
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
Заметил в ghci 9.4.8: > :t (<*>) @((->)_) (<*>) @((->)_) :: (w -> (a -> b)) -> (w -> a) -> w -> b Разве не должно (w -> (a -> b)) быть записано как (w -> a -> b)? Это баг, ил...
Михаил
13
А еще в перле можно уже @arr1 + @arr2?
Sergei Zhmylove
53
Any electron dev here?
Sayanth Tezro
12
Подобного рода ;Следующие три строки это директивы ассемблера, ;которые можно не задавать, т.к.работаем в Visual Studio. ;Символ ";" - это начало однострочного комментария ...
Егор Анелькин
3
Привет всем. появился вопрос. Разрабатываю сайт, в данный момент он запущен. Хостинг beget. Добавляю на сайт яндекс метрику с помощью полей client-settings (взято отсюда http...
Andrew
2
Кто-нибудь знает почему SPM клонирует репо целиком? Некоторые репы просто огромные, как та же swift-syntax которая нужна для использования макросов. Сначала подумал, что это...
iMike
6
Подскажите, где смотреть результат выполнения программы? Код: ;.686 ;Система команд процессора 686 ;.MODEL FLAT,stdcall ;Модель памяти плоская, станда...
Егор Анелькин
5
Привет. Я верно понимаю, что в определении класса Монад m — зафиксирован (к тому же поскольку это моноид в категории эндофункторов). Т.е. используя байнд я не могу перемещать...
Arseny
5
Карта сайта